mirror of https://github.com/apache/lucene.git
Remove SingleValueDocValuesFieldUpdates abstract class
This commit is contained in:
parent
b9385a8a29
commit
4d8771b0fe
|
@ -20,13 +20,10 @@ import static org.apache.lucene.search.DocIdSetIterator.NO_MORE_DOCS;
|
|||
|
||||
import org.apache.lucene.search.DocIdSetIterator;
|
||||
import org.apache.lucene.util.Accountable;
|
||||
import org.apache.lucene.util.BitSet;
|
||||
import org.apache.lucene.util.BitSetIterator;
|
||||
import org.apache.lucene.util.BytesRef;
|
||||
import org.apache.lucene.util.IntroSorter;
|
||||
import org.apache.lucene.util.PriorityQueue;
|
||||
import org.apache.lucene.util.RamUsageEstimator;
|
||||
import org.apache.lucene.util.SparseFixedBitSet;
|
||||
import org.apache.lucene.util.packed.PackedInts;
|
||||
import org.apache.lucene.util.packed.PagedMutable;
|
||||
|
||||
|
@ -480,107 +477,4 @@ abstract class DocValuesFieldUpdates implements Accountable {
|
|||
return hasValue;
|
||||
}
|
||||
}
|
||||
|
||||
abstract static class SingleValueDocValuesFieldUpdates extends DocValuesFieldUpdates {
|
||||
private final BitSet bitSet;
|
||||
private BitSet hasNoValue;
|
||||
private boolean hasAtLeastOneValue;
|
||||
|
||||
protected SingleValueDocValuesFieldUpdates(
|
||||
int maxDoc, long delGen, String field, DocValuesType type) {
|
||||
super(maxDoc, delGen, field, type);
|
||||
this.bitSet = new SparseFixedBitSet(maxDoc);
|
||||
}
|
||||
|
||||
@Override
|
||||
void add(int doc, long value) {
|
||||
assert longValue() == value;
|
||||
bitSet.set(doc);
|
||||
this.hasAtLeastOneValue = true;
|
||||
if (hasNoValue != null) {
|
||||
hasNoValue.clear(doc);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
void add(int doc, BytesRef value) {
|
||||
assert binaryValue().equals(value);
|
||||
bitSet.set(doc);
|
||||
this.hasAtLeastOneValue = true;
|
||||
if (hasNoValue != null) {
|
||||
hasNoValue.clear(doc);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
synchronized void reset(int doc) {
|
||||
bitSet.set(doc);
|
||||
this.hasAtLeastOneValue = true;
|
||||
if (hasNoValue == null) {
|
||||
hasNoValue = new SparseFixedBitSet(maxDoc);
|
||||
}
|
||||
hasNoValue.set(doc);
|
||||
}
|
||||
|
||||
@Override
|
||||
void add(int docId, Iterator iterator) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
protected abstract BytesRef binaryValue();
|
||||
|
||||
protected abstract long longValue();
|
||||
|
||||
@Override
|
||||
synchronized boolean any() {
|
||||
return super.any() || hasAtLeastOneValue;
|
||||
}
|
||||
|
||||
@Override
|
||||
public long ramBytesUsed() {
|
||||
return super.ramBytesUsed()
|
||||
+ bitSet.ramBytesUsed()
|
||||
+ (hasNoValue == null ? 0 : hasNoValue.ramBytesUsed());
|
||||
}
|
||||
|
||||
@Override
|
||||
Iterator iterator() {
|
||||
BitSetIterator iterator = new BitSetIterator(bitSet, maxDoc);
|
||||
return new DocValuesFieldUpdates.Iterator() {
|
||||
|
||||
@Override
|
||||
public int docID() {
|
||||
return iterator.docID();
|
||||
}
|
||||
|
||||
@Override
|
||||
public int nextDoc() {
|
||||
return iterator.nextDoc();
|
||||
}
|
||||
|
||||
@Override
|
||||
long longValue() {
|
||||
return SingleValueDocValuesFieldUpdates.this.longValue();
|
||||
}
|
||||
|
||||
@Override
|
||||
BytesRef binaryValue() {
|
||||
return SingleValueDocValuesFieldUpdates.this.binaryValue();
|
||||
}
|
||||
|
||||
@Override
|
||||
long delGen() {
|
||||
return delGen;
|
||||
}
|
||||
|
||||
@Override
|
||||
boolean hasValue() {
|
||||
if (hasNoValue != null) {
|
||||
return hasNoValue.get(docID()) == false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -17,8 +17,11 @@
|
|||
package org.apache.lucene.index;
|
||||
|
||||
import org.apache.lucene.document.NumericDocValuesField;
|
||||
import org.apache.lucene.util.BitSet;
|
||||
import org.apache.lucene.util.BitSetIterator;
|
||||
import org.apache.lucene.util.BytesRef;
|
||||
import org.apache.lucene.util.RamUsageEstimator;
|
||||
import org.apache.lucene.util.SparseFixedBitSet;
|
||||
import org.apache.lucene.util.packed.AbstractPagedMutable;
|
||||
import org.apache.lucene.util.packed.PackedInts;
|
||||
import org.apache.lucene.util.packed.PagedGrowableWriter;
|
||||
|
@ -130,23 +133,104 @@ final class NumericDocValuesFieldUpdates extends DocValuesFieldUpdates {
|
|||
+ RamUsageEstimator.NUM_BYTES_OBJECT_REF;
|
||||
}
|
||||
|
||||
static class SingleValueNumericDocValuesFieldUpdates extends SingleValueDocValuesFieldUpdates {
|
||||
static class SingleValueNumericDocValuesFieldUpdates extends DocValuesFieldUpdates {
|
||||
|
||||
private final long value;
|
||||
private final BitSet bitSet;
|
||||
private BitSet hasNoValue;
|
||||
private boolean hasAtLeastOneValue;
|
||||
|
||||
SingleValueNumericDocValuesFieldUpdates(long delGen, String field, int maxDoc, long value) {
|
||||
super(maxDoc, delGen, field, DocValuesType.NUMERIC);
|
||||
this.bitSet = new SparseFixedBitSet(maxDoc);
|
||||
this.value = value;
|
||||
}
|
||||
|
||||
// pkg private for testing
|
||||
long longValue() {
|
||||
return value;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected BytesRef binaryValue() {
|
||||
void add(int doc, long value) {
|
||||
assert this.value == value;
|
||||
bitSet.set(doc);
|
||||
this.hasAtLeastOneValue = true;
|
||||
if (hasNoValue != null) {
|
||||
hasNoValue.clear(doc);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
void add(int doc, BytesRef value) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected long longValue() {
|
||||
synchronized void reset(int doc) {
|
||||
bitSet.set(doc);
|
||||
this.hasAtLeastOneValue = true;
|
||||
if (hasNoValue == null) {
|
||||
hasNoValue = new SparseFixedBitSet(maxDoc);
|
||||
}
|
||||
hasNoValue.set(doc);
|
||||
}
|
||||
|
||||
@Override
|
||||
void add(int docId, Iterator iterator) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
@Override
|
||||
synchronized boolean any() {
|
||||
return super.any() || hasAtLeastOneValue;
|
||||
}
|
||||
|
||||
@Override
|
||||
public long ramBytesUsed() {
|
||||
return super.ramBytesUsed()
|
||||
+ bitSet.ramBytesUsed()
|
||||
+ (hasNoValue == null ? 0 : hasNoValue.ramBytesUsed());
|
||||
}
|
||||
|
||||
@Override
|
||||
Iterator iterator() {
|
||||
BitSetIterator iterator = new BitSetIterator(bitSet, maxDoc);
|
||||
return new DocValuesFieldUpdates.Iterator() {
|
||||
|
||||
@Override
|
||||
public int docID() {
|
||||
return iterator.docID();
|
||||
}
|
||||
|
||||
@Override
|
||||
public int nextDoc() {
|
||||
return iterator.nextDoc();
|
||||
}
|
||||
|
||||
@Override
|
||||
long longValue() {
|
||||
return value;
|
||||
}
|
||||
|
||||
@Override
|
||||
BytesRef binaryValue() {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
@Override
|
||||
long delGen() {
|
||||
return delGen;
|
||||
}
|
||||
|
||||
@Override
|
||||
boolean hasValue() {
|
||||
if (hasNoValue != null) {
|
||||
return hasNoValue.get(docID()) == false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue