mirror of https://github.com/apache/lucene.git
move datastructures for numerics back to codec
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/branches/lucene4547@1411215 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
898ae3f93b
commit
178c07f4e4
|
@ -400,19 +400,21 @@ class FieldCacheImpl implements FieldCache {
|
|||
protected Object createValue(AtomicReader reader, CacheKey key, boolean setDocsWithField)
|
||||
throws IOException {
|
||||
|
||||
int maxDoc = reader.maxDoc();
|
||||
final byte[] values;
|
||||
|
||||
NumericDocValues valuesIn = reader.getNumericDocValues(key.field);
|
||||
if (valuesIn != null) {
|
||||
final NumericDocValues ramInstance = valuesIn.newRAMInstance();
|
||||
return new Bytes() {
|
||||
@Override
|
||||
public byte get(int docID) {
|
||||
return (byte) ramInstance.get(docID);
|
||||
}
|
||||
};
|
||||
// nocommit should we throw exc if parser isn't
|
||||
// null? if setDocsWithField is true?
|
||||
values = new byte[maxDoc];
|
||||
for(int docID=0;docID<maxDoc;docID++) {
|
||||
values[docID] = (byte) valuesIn.get(docID);
|
||||
}
|
||||
} else {
|
||||
|
||||
int maxDoc = reader.maxDoc();
|
||||
final byte[] values;
|
||||
final ByteParser parser = (ByteParser) key.custom;
|
||||
if (parser == null) {
|
||||
// Confusing: must delegate to wrapper (vs simply
|
||||
|
@ -442,11 +444,11 @@ class FieldCacheImpl implements FieldCache {
|
|||
if (setDocsWithField) {
|
||||
wrapper.setDocsWithField(reader, key.field, u.docsWithField);
|
||||
}
|
||||
}
|
||||
|
||||
return new BytesFromArray(values);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// inherit javadocs
|
||||
public Shorts getShorts (AtomicReader reader, String field, boolean setDocsWithField) throws IOException {
|
||||
|
@ -482,18 +484,20 @@ class FieldCacheImpl implements FieldCache {
|
|||
protected Object createValue(AtomicReader reader, CacheKey key, boolean setDocsWithField)
|
||||
throws IOException {
|
||||
|
||||
int maxDoc = reader.maxDoc();
|
||||
final short[] values;
|
||||
|
||||
NumericDocValues valuesIn = reader.getNumericDocValues(key.field);
|
||||
if (valuesIn != null) {
|
||||
final NumericDocValues ramInstance = valuesIn.newRAMInstance();
|
||||
return new Shorts() {
|
||||
@Override
|
||||
public short get(int docID) {
|
||||
return (short) ramInstance.get(docID);
|
||||
}
|
||||
};
|
||||
// nocommit should we throw exc if parser isn't
|
||||
// null? if setDocsWithField is true?
|
||||
values = new short[maxDoc];
|
||||
for(int docID=0;docID<maxDoc;docID++) {
|
||||
values[docID] = (short) valuesIn.get(docID);
|
||||
}
|
||||
} else {
|
||||
int maxDoc = reader.maxDoc();
|
||||
final short[] values;
|
||||
final ShortParser parser = (ShortParser) key.custom;
|
||||
if (parser == null) {
|
||||
// Confusing: must delegate to wrapper (vs simply
|
||||
|
@ -522,10 +526,10 @@ class FieldCacheImpl implements FieldCache {
|
|||
if (setDocsWithField) {
|
||||
wrapper.setDocsWithField(reader, key.field, u.docsWithField);
|
||||
}
|
||||
}
|
||||
return new ShortsFromArray(values);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// inherit javadocs
|
||||
public Ints getInts (AtomicReader reader, String field, boolean setDocsWithField) throws IOException {
|
||||
|
@ -561,18 +565,20 @@ class FieldCacheImpl implements FieldCache {
|
|||
protected Object createValue(final AtomicReader reader, CacheKey key, boolean setDocsWithField)
|
||||
throws IOException {
|
||||
|
||||
int maxDoc = reader.maxDoc();
|
||||
final int[] values;
|
||||
NumericDocValues valuesIn = reader.getNumericDocValues(key.field);
|
||||
if (valuesIn != null) {
|
||||
final NumericDocValues ramInstance = valuesIn.newRAMInstance();
|
||||
return new Ints() {
|
||||
@Override
|
||||
public int get(int docID) {
|
||||
return (int) ramInstance.get(docID);
|
||||
}
|
||||
};
|
||||
// nocommit should we throw exc if parser isn't
|
||||
// null? if setDocsWithField is true?
|
||||
values = new int[maxDoc];
|
||||
for(int docID=0;docID<maxDoc;docID++) {
|
||||
values[docID] = (int) valuesIn.get(docID);
|
||||
}
|
||||
} else {
|
||||
|
||||
int maxDoc = reader.maxDoc();
|
||||
final int[] values;
|
||||
final IntParser parser = (IntParser) key.custom;
|
||||
if (parser == null) {
|
||||
// Confusing: must delegate to wrapper (vs simply
|
||||
|
@ -610,10 +616,10 @@ class FieldCacheImpl implements FieldCache {
|
|||
if (setDocsWithField) {
|
||||
wrapper.setDocsWithField(reader, key.field, u.docsWithField);
|
||||
}
|
||||
}
|
||||
return new IntsFromArray(values);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// nocommit must advertise that this does NOT work if you
|
||||
// index only doc values for the field ... it will say no
|
||||
|
@ -713,21 +719,20 @@ class FieldCacheImpl implements FieldCache {
|
|||
protected Object createValue(AtomicReader reader, CacheKey key, boolean setDocsWithField)
|
||||
throws IOException {
|
||||
|
||||
int maxDoc = reader.maxDoc();
|
||||
final float[] values;
|
||||
|
||||
NumericDocValues valuesIn = reader.getNumericDocValues(key.field);
|
||||
if (valuesIn != null) {
|
||||
final NumericDocValues ramInstance = valuesIn.newRAMInstance();
|
||||
return new Floats() {
|
||||
@Override
|
||||
public float get(int docID) {
|
||||
return Float.intBitsToFloat((int) ramInstance.get(docID));
|
||||
}
|
||||
};
|
||||
// nocommit should we throw exc if parser isn't
|
||||
// null? if setDocsWithField is true?
|
||||
values = new float[maxDoc];
|
||||
for(int docID=0;docID<maxDoc;docID++) {
|
||||
// nocommit somewhat dangerous ... eg if user had
|
||||
// indexed as DV.BYTE ...
|
||||
values[docID] = Float.intBitsToFloat((int) valuesIn.get(docID));
|
||||
}
|
||||
} else {
|
||||
|
||||
int maxDoc = reader.maxDoc();
|
||||
final float[] values;
|
||||
final FloatParser parser = (FloatParser) key.custom;
|
||||
if (parser == null) {
|
||||
// Confusing: must delegate to wrapper (vs simply
|
||||
|
@ -765,11 +770,11 @@ class FieldCacheImpl implements FieldCache {
|
|||
if (setDocsWithField) {
|
||||
wrapper.setDocsWithField(reader, key.field, u.docsWithField);
|
||||
}
|
||||
}
|
||||
|
||||
return new FloatsFromArray(values);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// inherit javadocs
|
||||
public Longs getLongs(AtomicReader reader, String field, boolean setDocsWithField) throws IOException {
|
||||
|
@ -805,17 +810,20 @@ class FieldCacheImpl implements FieldCache {
|
|||
protected Object createValue(AtomicReader reader, CacheKey key, boolean setDocsWithField)
|
||||
throws IOException {
|
||||
|
||||
int maxDoc = reader.maxDoc();
|
||||
final long[] values;
|
||||
NumericDocValues valuesIn = reader.getNumericDocValues(key.field);
|
||||
if (valuesIn != null) {
|
||||
final NumericDocValues ramInstance = valuesIn.newRAMInstance();
|
||||
return new Longs() {
|
||||
@Override
|
||||
public long get(int docID) {
|
||||
return ramInstance.get(docID);
|
||||
}
|
||||
};
|
||||
// nocommit should we throw exc if parser isn't
|
||||
// null? if setDocsWithField is true?
|
||||
values = new long[maxDoc];
|
||||
for(int docID=0;docID<maxDoc;docID++) {
|
||||
values[docID] = valuesIn.get(docID);
|
||||
}
|
||||
} else {
|
||||
int maxDoc = reader.maxDoc();
|
||||
final long[] values;
|
||||
final LongParser parser = (LongParser) key.custom;
|
||||
if (parser == null) {
|
||||
// Confusing: must delegate to wrapper (vs simply
|
||||
|
@ -853,10 +861,10 @@ class FieldCacheImpl implements FieldCache {
|
|||
if (setDocsWithField) {
|
||||
wrapper.setDocsWithField(reader, key.field, u.docsWithField);
|
||||
}
|
||||
}
|
||||
return new LongsFromArray(values);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// inherit javadocs
|
||||
public Doubles getDoubles(AtomicReader reader, String field, boolean setDocsWithField)
|
||||
|
@ -892,20 +900,21 @@ class FieldCacheImpl implements FieldCache {
|
|||
@Override
|
||||
protected Object createValue(AtomicReader reader, CacheKey key, boolean setDocsWithField)
|
||||
throws IOException {
|
||||
int maxDoc = reader.maxDoc();
|
||||
final double[] values;
|
||||
|
||||
NumericDocValues valuesIn = reader.getNumericDocValues(key.field);
|
||||
if (valuesIn != null) {
|
||||
final NumericDocValues ramInstance = valuesIn.newRAMInstance();
|
||||
return new Doubles() {
|
||||
@Override
|
||||
public double get(int docID) {
|
||||
return Double.longBitsToDouble(ramInstance.get(docID));
|
||||
}
|
||||
};
|
||||
// nocommit should we throw exc if parser isn't
|
||||
// null? if setDocsWithField is true?
|
||||
values = new double[maxDoc];
|
||||
for(int docID=0;docID<maxDoc;docID++) {
|
||||
// nocommit somewhat dangerous ... eg if user had
|
||||
// indexed as DV.BYTE ...
|
||||
values[docID] = Double.longBitsToDouble(valuesIn.get(docID));
|
||||
}
|
||||
} else {
|
||||
int maxDoc = reader.maxDoc();
|
||||
final double[] values;
|
||||
final DoubleParser parser = (DoubleParser) key.custom;
|
||||
if (parser == null) {
|
||||
// Confusing: must delegate to wrapper (vs simply
|
||||
|
@ -943,10 +952,10 @@ class FieldCacheImpl implements FieldCache {
|
|||
if (setDocsWithField) {
|
||||
wrapper.setDocsWithField(reader, key.field, u.docsWithField);
|
||||
}
|
||||
}
|
||||
return new DoublesFromArray(values);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static class DocTermsIndexImpl extends DocTermsIndex {
|
||||
private final PagedBytes.Reader bytes;
|
||||
|
|
Loading…
Reference in New Issue