Skip to content

Commit

Permalink
Modernize LineFileDocs. (#12929)
Browse files Browse the repository at this point in the history
This replaces `StringField`/`SortedDocValuesField` with `KeywordField` and
`IntPoint`/`NumericDocValuesField` with `IntField`.
  • Loading branch information
jpountz authored Dec 19, 2023
1 parent 5c084fc commit bcc7e12
Show file tree
Hide file tree
Showing 5 changed files with 27 additions and 20 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ public void test() throws Exception {
}
if (random().nextInt(15) == 0) {
riw.updateNumericDocValue(
new Term("docid", Integer.toString(i)), "docid_intDV", Long.valueOf(i));
new Term("docid", Integer.toString(i)), "page_views", Long.valueOf(i));
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ public void test() throws Exception {
}
if (random().nextInt(15) == 0) {
riw.updateNumericDocValue(
new Term("docid", Integer.toString(i)), "docid_intDV", Long.valueOf(i));
new Term("docid", Integer.toString(i)), "page_views", Long.valueOf(i));
}
}
riw.close();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ public void test() throws Exception {
}
if (random().nextInt(15) == 0) {
riw.updateNumericDocValue(
new Term("docid", Integer.toString(i)), "docid_intDV", Long.valueOf(i));
new Term("docid", Integer.toString(i)), "page_views", Long.valueOf(i));
}
}
riw.close();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,14 +37,14 @@
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.document.FieldType;
import org.apache.lucene.document.IntField;
import org.apache.lucene.document.IntPoint;
import org.apache.lucene.document.KeywordField;
import org.apache.lucene.document.NumericDocValuesField;
import org.apache.lucene.document.SortedDocValuesField;
import org.apache.lucene.document.StringField;
import org.apache.lucene.document.TextField;
import org.apache.lucene.index.IndexOptions;
import org.apache.lucene.index.IndexableField;
import org.apache.lucene.util.BytesRef;
import org.apache.lucene.util.CloseableThreadLocal;
import org.apache.lucene.util.IOUtils;

Expand Down Expand Up @@ -199,17 +199,16 @@ private static final class DocState {
final Document doc;
final Field titleTokenized;
final Field title;
final Field titleDV;
final Field body;
final Field id;
final Field idNum;
final Field idNumDV;
final Field date;
final Field pageViews;

public DocState() {
doc = new Document();

title = new StringField("title", "", Field.Store.NO);
title = new KeywordField("title", "", Field.Store.NO);
doc.add(title);

FieldType ft = new FieldType(TextField.TYPE_STORED);
Expand All @@ -227,16 +226,15 @@ public DocState() {
id = new StringField("docid", "", Field.Store.YES);
doc.add(id);

idNum = new IntPoint("docid_int", 0);
idNum = new IntField("docid_int", 0, Field.Store.NO);
doc.add(idNum);

date = new StringField("date", "", Field.Store.YES);
doc.add(date);

titleDV = new SortedDocValuesField("titleDV", new BytesRef());
idNumDV = new NumericDocValuesField("docid_intDV", 0);
doc.add(titleDV);
doc.add(idNumDV);
// A numeric DV field that can be used for DV updates
pageViews = new NumericDocValuesField("page_views", 0L);
doc.add(pageViews);
}
}

Expand Down Expand Up @@ -277,17 +275,12 @@ public Document nextDoc() throws IOException {
docState.body.setStringValue(line.substring(1 + spot2, line.length()));
final String title = line.substring(0, spot);
docState.title.setStringValue(title);
if (docState.titleDV != null) {
docState.titleDV.setBytesValue(new BytesRef(title));
}
docState.titleTokenized.setStringValue(title);
docState.date.setStringValue(line.substring(1 + spot, spot2));
final int i = id.getAndIncrement();
docState.id.setStringValue(Integer.toString(i));
docState.idNum.setIntValue(i);
if (docState.idNumDV != null) {
docState.idNumDV.setLongValue(i);
}
docState.pageViews.setLongValue(random.nextInt(10_000));

if (random.nextInt(5) == 4) {
// Make some sparse fields
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,8 @@
import org.apache.lucene.document.BinaryPoint;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.document.IntField;
import org.apache.lucene.document.KeywordField;
import org.apache.lucene.document.NumericDocValuesField;
import org.apache.lucene.document.SortedDocValuesField;
import org.apache.lucene.index.CheckIndex;
Expand Down Expand Up @@ -1420,7 +1422,19 @@ public static Document cloneDocument(Document doc1) {
final Field field2;
final DocValuesType dvType = field1.fieldType().docValuesType();
final int dimCount = field1.fieldType().pointDimensionCount();
if (dvType != DocValuesType.NONE) {
if (f instanceof KeywordField) {
field2 =
new KeywordField(
f.name(),
f.stringValue(),
f.fieldType().stored() ? Field.Store.YES : Field.Store.NO);
} else if (f instanceof IntField) {
field2 =
new IntField(
f.name(),
f.numericValue().intValue(),
f.fieldType().stored() ? Field.Store.YES : Field.Store.NO);
} else if (dvType != DocValuesType.NONE) {
switch (dvType) {
case NUMERIC:
field2 = new NumericDocValuesField(field1.name(), field1.numericValue().longValue());
Expand Down

0 comments on commit bcc7e12

Please sign in to comment.