blob: d5929fcde60d7c9d0b027effe1b677c1a0d633b4 [file] [log] [blame]
using Lucene.Net.Documents;
namespace Lucene.Net.Index
{
using BytesRef = Lucene.Net.Util.BytesRef;
using NumericDocValuesField = NumericDocValuesField;
using RamUsageEstimator = Lucene.Net.Util.RamUsageEstimator;
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/// <summary>
/// An in-place update to a DocValues field. </summary>
public abstract class DocValuesUpdate
{
/* Rough logic: OBJ_HEADER + 3*PTR + INT
* Term: OBJ_HEADER + 2*PTR
* Term.field: 2*OBJ_HEADER + 4*INT + PTR + string.length*CHAR
* Term.bytes: 2*OBJ_HEADER + 2*INT + PTR + bytes.length
* String: 2*OBJ_HEADER + 4*INT + PTR + string.length*CHAR
* T: OBJ_HEADER
*/
private static readonly int RAW_SIZE_IN_BYTES = 8 * RamUsageEstimator.NUM_BYTES_OBJECT_HEADER + 8 * RamUsageEstimator.NUM_BYTES_OBJECT_REF + 8 * RamUsageEstimator.NUM_BYTES_INT;
internal readonly DocValuesFieldUpdates.Type_e Type;
internal readonly Term Term;
internal readonly string Field;
internal readonly object Value;
internal int DocIDUpto = -1; // unassigned until applied, and confusing that it's here, when it's just used in BufferedDeletes...
/// <summary>
/// Constructor.
/// </summary>
/// <param name="term"> the <seealso cref="Term"/> which determines the documents that will be updated </param>
/// <param name="field"> the <seealso cref="NumericDocValuesField"/> to update </param>
/// <param name="value"> the updated value </param>
protected internal DocValuesUpdate(DocValuesFieldUpdates.Type_e type, Term term, string field, object value)
{
this.Type = type;
this.Term = term;
this.Field = field;
this.Value = value;
}
internal abstract long ValueSizeInBytes();
internal int SizeInBytes()
{
int sizeInBytes = RAW_SIZE_IN_BYTES;
sizeInBytes += Term.Field.Length * RamUsageEstimator.NUM_BYTES_CHAR;
sizeInBytes += Term.Bytes.Bytes.Length;
sizeInBytes += Field.Length * RamUsageEstimator.NUM_BYTES_CHAR;
sizeInBytes += (int)ValueSizeInBytes();
return sizeInBytes;
}
public override string ToString()
{
return "term=" + Term + ",field=" + Field + ",value=" + Value;
}
/// <summary>
/// An in-place update to a binary DocValues field </summary>
public sealed class BinaryDocValuesUpdate : DocValuesUpdate
{
/* Size of BytesRef: 2*INT + ARRAY_HEADER + PTR */
internal static readonly long RAW_VALUE_SIZE_IN_BYTES = RamUsageEstimator.NUM_BYTES_ARRAY_HEADER + 2 * RamUsageEstimator.NUM_BYTES_INT + RamUsageEstimator.NUM_BYTES_OBJECT_REF;
internal static readonly BytesRef MISSING = new BytesRef();
internal BinaryDocValuesUpdate(Term term, string field, BytesRef value)
: base(DocValuesFieldUpdates.Type_e.BINARY, term, field, value == null ? MISSING : value)
{
}
internal override long ValueSizeInBytes()
{
return RAW_VALUE_SIZE_IN_BYTES + ((BytesRef)Value).Bytes.Length;
}
}
/// <summary>
/// An in-place update to a numeric DocValues field </summary>
public sealed class NumericDocValuesUpdate : DocValuesUpdate
{
internal static readonly long? MISSING = new long?(0);
public NumericDocValuesUpdate(Term term, string field, long? value)
: base(DocValuesFieldUpdates.Type_e.NUMERIC, term, field, value == null ? MISSING : value)
{
}
internal override long ValueSizeInBytes()
{
return RamUsageEstimator.NUM_BYTES_LONG;
}
}
}
}