mirror of https://github.com/apache/lucene.git
ant test -Dtestcase=TestDemoDocValue -Dtests.codec=SimpleText
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/branches/lucene4547@1409644 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
9a3c403b26
commit
88c85749bf
|
@ -24,6 +24,7 @@ import org.apache.lucene.codecs.LiveDocsFormat;
|
||||||
import org.apache.lucene.codecs.NormsFormat;
|
import org.apache.lucene.codecs.NormsFormat;
|
||||||
import org.apache.lucene.codecs.PostingsFormat;
|
import org.apache.lucene.codecs.PostingsFormat;
|
||||||
import org.apache.lucene.codecs.SegmentInfoFormat;
|
import org.apache.lucene.codecs.SegmentInfoFormat;
|
||||||
|
import org.apache.lucene.codecs.SimpleDocValuesFormat;
|
||||||
import org.apache.lucene.codecs.StoredFieldsFormat;
|
import org.apache.lucene.codecs.StoredFieldsFormat;
|
||||||
import org.apache.lucene.codecs.TermVectorsFormat;
|
import org.apache.lucene.codecs.TermVectorsFormat;
|
||||||
|
|
||||||
|
@ -88,4 +89,13 @@ public final class SimpleTextCodec extends Codec {
|
||||||
public LiveDocsFormat liveDocsFormat() {
|
public LiveDocsFormat liveDocsFormat() {
|
||||||
return liveDocs;
|
return liveDocs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// nocommit;
|
||||||
|
private final SimpleDocValuesFormat nocommit = new SimpleTextSimpleDocValuesFormat();
|
||||||
|
@Override
|
||||||
|
public SimpleDocValuesFormat simpleDocValuesFormat() {
|
||||||
|
return nocommit;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -369,6 +369,7 @@ public class SimpleTextSimpleDocValuesFormat extends SimpleDocValuesFormat {
|
||||||
readLine();
|
readLine();
|
||||||
assert startsWith(PATTERN);
|
assert startsWith(PATTERN);
|
||||||
field.pattern = stripPrefix(PATTERN);
|
field.pattern = stripPrefix(PATTERN);
|
||||||
|
field.dataStartFilePointer = data.getFilePointer();
|
||||||
data.seek(data.getFilePointer() + (1+field.pattern.length()) * maxDoc);
|
data.seek(data.getFilePointer() + (1+field.pattern.length()) * maxDoc);
|
||||||
} else if (DocValues.isBytes(dvType)) {
|
} else if (DocValues.isBytes(dvType)) {
|
||||||
readLine();
|
readLine();
|
||||||
|
@ -377,6 +378,7 @@ public class SimpleTextSimpleDocValuesFormat extends SimpleDocValuesFormat {
|
||||||
readLine();
|
readLine();
|
||||||
assert startsWith(PATTERN);
|
assert startsWith(PATTERN);
|
||||||
field.pattern = stripPrefix(PATTERN);
|
field.pattern = stripPrefix(PATTERN);
|
||||||
|
field.dataStartFilePointer = data.getFilePointer();
|
||||||
data.seek(data.getFilePointer() + (9+field.pattern.length()+field.maxLength) * maxDoc);
|
data.seek(data.getFilePointer() + (9+field.pattern.length()+field.maxLength) * maxDoc);
|
||||||
break;
|
break;
|
||||||
} else if (DocValues.isSortedBytes(dvType)) {
|
} else if (DocValues.isSortedBytes(dvType)) {
|
||||||
|
@ -392,12 +394,13 @@ public class SimpleTextSimpleDocValuesFormat extends SimpleDocValuesFormat {
|
||||||
readLine();
|
readLine();
|
||||||
assert startsWith(ORDPATTERN);
|
assert startsWith(ORDPATTERN);
|
||||||
field.ordPattern = stripPrefix(ORDPATTERN);
|
field.ordPattern = stripPrefix(ORDPATTERN);
|
||||||
|
field.dataStartFilePointer = data.getFilePointer();
|
||||||
|
// nocommit: we need to seek past the data section!!!!
|
||||||
} else if (DocValues.isFloat(dvType)) {
|
} else if (DocValues.isFloat(dvType)) {
|
||||||
// nocommit
|
// nocommit
|
||||||
} else {
|
} else {
|
||||||
throw new AssertionError();
|
throw new AssertionError();
|
||||||
}
|
}
|
||||||
field.dataStartFilePointer = data.getFilePointer();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -515,7 +518,15 @@ public class SimpleTextSimpleDocValuesFormat extends SimpleDocValuesFormat {
|
||||||
// value from the wrong field ...
|
// value from the wrong field ...
|
||||||
in.seek(field.dataStartFilePointer + (1+field.pattern.length())*docID);
|
in.seek(field.dataStartFilePointer + (1+field.pattern.length())*docID);
|
||||||
SimpleTextUtil.readLine(in, scratch);
|
SimpleTextUtil.readLine(in, scratch);
|
||||||
return decoder.parse(scratch.utf8ToString(), pos).longValue();
|
System.out.println("trying to parse number: " + scratch.utf8ToString());
|
||||||
|
// nocommit
|
||||||
|
long seekPos = field.dataStartFilePointer;
|
||||||
|
byte wholeFile[] = new byte[(int)(in.length()-seekPos)];
|
||||||
|
IndexInput foo = in.clone();
|
||||||
|
foo.seek(seekPos);
|
||||||
|
foo.readBytes(wholeFile, 0, wholeFile.length);
|
||||||
|
System.out.println("rest: " + new String(wholeFile, 0, wholeFile.length, "UTF-8"));
|
||||||
|
return field.minValue + decoder.parse(scratch.utf8ToString(), pos).longValue();
|
||||||
} catch (IOException ioe) {
|
} catch (IOException ioe) {
|
||||||
throw new RuntimeException(ioe);
|
throw new RuntimeException(ioe);
|
||||||
}
|
}
|
||||||
|
|
|
@ -147,7 +147,8 @@ final class DocFieldProcessor extends DocConsumer {
|
||||||
}
|
}
|
||||||
|
|
||||||
// close perDocConsumer during flush to ensure all files are flushed due to PerCodec CFS
|
// close perDocConsumer during flush to ensure all files are flushed due to PerCodec CFS
|
||||||
IOUtils.close(perDocConsumer);
|
// nocommit
|
||||||
|
IOUtils.close(perDocConsumer, dvConsumer);
|
||||||
|
|
||||||
// Important to save after asking consumer to flush so
|
// Important to save after asking consumer to flush so
|
||||||
// consumer can alter the FieldInfo* if necessary. EG,
|
// consumer can alter the FieldInfo* if necessary. EG,
|
||||||
|
|
|
@ -110,7 +110,8 @@ final class SegmentCoreReaders {
|
||||||
// TODO: since we don't write any norms file if there are no norms,
|
// TODO: since we don't write any norms file if there are no norms,
|
||||||
// kinda jaky to assume the codec handles the case of no norms file at all gracefully?!
|
// kinda jaky to assume the codec handles the case of no norms file at all gracefully?!
|
||||||
norms = codec.normsFormat().docsProducer(segmentReadState);
|
norms = codec.normsFormat().docsProducer(segmentReadState);
|
||||||
perDocProducer = codec.docValuesFormat().docsProducer(segmentReadState);
|
// nocommit
|
||||||
|
perDocProducer = codec.simpleDocValuesFormat().fieldsProducer(segmentReadState);
|
||||||
|
|
||||||
fieldsReaderOrig = si.info.getCodec().storedFieldsFormat().fieldsReader(cfsDir, si.info, fieldInfos, context);
|
fieldsReaderOrig = si.info.getCodec().storedFieldsFormat().fieldsReader(cfsDir, si.info, fieldInfos, context);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue