SOLR-1930: fully move from Field to Fieldable in interfaces

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1054763 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Yonik Seeley 2011-01-03 21:30:50 +00:00
parent 64e6e196ac
commit 3fa3cf5493
10 changed files with 17 additions and 19 deletions

View File

@ -50,7 +50,7 @@ public class BinaryField extends FieldType {
return ByteBuffer.wrap(f.getBinaryValue(), f.getBinaryOffset(), f.getBinaryLength() ) ; return ByteBuffer.wrap(f.getBinaryValue(), f.getBinaryOffset(), f.getBinaryLength() ) ;
} }
public Field createField(SchemaField field, Object val, float boost) { public Fieldable createField(SchemaField field, Object val, float boost) {
if (val == null) return null; if (val == null) return null;
if (!field.stored()) { if (!field.stored()) {
log.trace("Ignoring unstored binary field: " + field); log.trace("Ignoring unstored binary field: " + field);

View File

@ -221,7 +221,7 @@ public abstract class FieldType extends FieldProperties {
* *
* *
*/ */
public Field createField(SchemaField field, String externalVal, float boost) { public Fieldable createField(SchemaField field, String externalVal, float boost) {
if (!field.indexed() && !field.stored()) { if (!field.indexed() && !field.stored()) {
if (log.isTraceEnabled()) if (log.isTraceEnabled())
log.trace("Ignoring unindexed/unstored field: " + field); log.trace("Ignoring unindexed/unstored field: " + field);
@ -252,9 +252,9 @@ public abstract class FieldType extends FieldProperties {
* @param omitNorms true if norms should be omitted * @param omitNorms true if norms should be omitted
* @param omitTFPos true if term freq and position should be omitted. * @param omitTFPos true if term freq and position should be omitted.
* @param boost The boost value * @param boost The boost value
* @return the {@link org.apache.lucene.document.Field}. * @return the {@link org.apache.lucene.document.Fieldable}.
*/ */
protected Field createField(String name, String val, Field.Store storage, Field.Index index, protected Fieldable createField(String name, String val, Field.Store storage, Field.Index index,
Field.TermVector vec, boolean omitNorms, boolean omitTFPos, float boost){ Field.TermVector vec, boolean omitNorms, boolean omitTFPos, float boost){
Field f = new Field(name, Field f = new Field(name,
val, val,
@ -278,7 +278,7 @@ public abstract class FieldType extends FieldProperties {
* @see #isPolyField() * @see #isPolyField()
*/ */
public Fieldable[] createFields(SchemaField field, String externalVal, float boost) { public Fieldable[] createFields(SchemaField field, String externalVal, float boost) {
Field f = createField( field, externalVal, boost); Fieldable f = createField( field, externalVal, boost);
return f==null ? new Fieldable[]{} : new Fieldable[]{f}; return f==null ? new Fieldable[]{} : new Fieldable[]{f};
} }
@ -341,7 +341,7 @@ public abstract class FieldType extends FieldProperties {
public Object toObject(SchemaField sf, BytesRef term) { public Object toObject(SchemaField sf, BytesRef term) {
CharArr ext = new CharArr(term.length); CharArr ext = new CharArr(term.length);
indexedToReadable(term, ext); indexedToReadable(term, ext);
Field f = createField(sf, ext.toString(), 1.0f); Fieldable f = createField(sf, ext.toString(), 1.0f);
return toObject(f); return toObject(f);
} }
@ -511,7 +511,6 @@ public abstract class FieldType extends FieldProperties {
* @param maxInclusive whether the maximum of the range is inclusive or not * @param maxInclusive whether the maximum of the range is inclusive or not
* @return a Query instance to perform range search according to given parameters * @return a Query instance to perform range search according to given parameters
* *
* @see org.apache.solr.search.SolrQueryParser#getRangeQuery(String, String, String, boolean)
*/ */
public Query getRangeQuery(QParser parser, SchemaField field, String part1, String part2, boolean minInclusive, boolean maxInclusive) { public Query getRangeQuery(QParser parser, SchemaField field, String part1, String part2, boolean minInclusive, boolean maxInclusive) {
// constant score mode is now enabled per default // constant score mode is now enabled per default

View File

@ -281,7 +281,7 @@ public class LatLonType extends AbstractSubTypeFieldType implements SpatialQuery
//It never makes sense to create a single field, so make it impossible to happen //It never makes sense to create a single field, so make it impossible to happen
@Override @Override
public Field createField(SchemaField field, String externalVal, float boost) { public Fieldable createField(SchemaField field, String externalVal, float boost) {
throw new UnsupportedOperationException("LatLonType uses multiple fields. field=" + field.getName()); throw new UnsupportedOperationException("LatLonType uses multiple fields. field=" + field.getName());
} }

View File

@ -112,7 +112,7 @@ public class PointType extends CoordinateFieldType implements SpatialQueryable {
* *
*/ */
@Override @Override
public Field createField(SchemaField field, String externalVal, float boost) { public Fieldable createField(SchemaField field, String externalVal, float boost) {
throw new UnsupportedOperationException("PointType uses multiple fields. field=" + field.getName()); throw new UnsupportedOperationException("PointType uses multiple fields. field=" + field.getName());
} }

View File

@ -89,7 +89,7 @@ public final class SchemaField extends FieldProperties {
boolean isBinary() { return (properties & BINARY)!=0; } boolean isBinary() { return (properties & BINARY)!=0; }
public Field createField(String val, float boost) { public Fieldable createField(String val, float boost) {
return type.createField(this,val,boost); return type.createField(this,val,boost);
} }

View File

@ -160,7 +160,7 @@ public class TrieDateField extends DateField {
} }
@Override @Override
public Field createField(SchemaField field, String externalVal, float boost) { public Fieldable createField(SchemaField field, String externalVal, float boost) {
boolean indexed = field.indexed(); boolean indexed = field.indexed();
boolean stored = field.stored(); boolean stored = field.stored();

View File

@ -477,7 +477,7 @@ public class TrieField extends FieldType {
} }
@Override @Override
public Field createField(SchemaField field, String externalVal, float boost) { public Fieldable createField(SchemaField field, String externalVal, float boost) {
boolean indexed = field.indexed(); boolean indexed = field.indexed();
boolean stored = field.stored(); boolean stored = field.stored();

View File

@ -73,7 +73,7 @@ public class DocumentBuilder {
} }
} }
} else { } else {
Field field = sfield.createField(val, boost); Fieldable field = sfield.createField(val, boost);
if (field != null) { if (field != null) {
if (!sfield.multiValued()) { if (!sfield.multiValued()) {
String oldValue = map.put(sfield.getName(), val); String oldValue = map.put(sfield.getName(), val);
@ -201,7 +201,7 @@ public class DocumentBuilder {
if (f != null) doc.add(f); // null fields are not added if (f != null) doc.add(f); // null fields are not added
} }
} else { } else {
Field f = field.createField(val, boost); Fieldable f = field.createField(val, boost);
if (f != null) doc.add(f); // null fields are not added if (f != null) doc.add(f); // null fields are not added
} }
} }

View File

@ -27,9 +27,8 @@ import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.lucene.document.Field; import org.apache.lucene.document.Field;
import org.apache.lucene.document.Fieldable;
import org.apache.lucene.index.LogMergePolicy; import org.apache.lucene.index.LogMergePolicy;
import org.apache.lucene.search.BooleanQuery;
import org.apache.lucene.search.Query;
import org.apache.solr.common.params.AppendedSolrParams; import org.apache.solr.common.params.AppendedSolrParams;
import org.apache.solr.common.params.CommonParams; import org.apache.solr.common.params.CommonParams;
import org.apache.solr.common.params.DefaultSolrParams; import org.apache.solr.common.params.DefaultSolrParams;
@ -47,7 +46,6 @@ import org.apache.solr.schema.IndexSchema;
import org.apache.solr.schema.SchemaField; import org.apache.solr.schema.SchemaField;
import org.apache.solr.search.DocIterator; import org.apache.solr.search.DocIterator;
import org.apache.solr.search.DocList; import org.apache.solr.search.DocList;
import org.apache.solr.search.QueryParsing;
import org.apache.solr.update.SolrIndexWriter; import org.apache.solr.update.SolrIndexWriter;
import org.junit.BeforeClass; import org.junit.BeforeClass;
import org.junit.Test; import org.junit.Test;
@ -350,7 +348,7 @@ public class BasicFunctionalityTest extends SolrTestCaseJ4 {
IndexSchema ischema = new IndexSchema(solrConfig, getSchemaFile(), null); IndexSchema ischema = new IndexSchema(solrConfig, getSchemaFile(), null);
SchemaField f; // Solr field type SchemaField f; // Solr field type
Field luf; // Lucene field Fieldable luf; // Lucene field
f = ischema.getField("test_basictv"); f = ischema.getField("test_basictv");
luf = f.createField("test", 0f); luf = f.createField("test", 0f);

View File

@ -19,6 +19,7 @@ package org.apache.solr.update;
import org.apache.lucene.document.Document; import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field; import org.apache.lucene.document.Field;
import org.apache.lucene.document.Fieldable;
import org.apache.solr.request.SolrQueryRequest; import org.apache.solr.request.SolrQueryRequest;
import org.apache.solr.schema.IndexSchema; import org.apache.solr.schema.IndexSchema;
import org.apache.solr.util.AbstractSolrTestCase; import org.apache.solr.util.AbstractSolrTestCase;
@ -99,7 +100,7 @@ public class TestIndexingPerformance extends AbstractSolrTestCase {
for (int j=0; j<fields.length; j+=2) { for (int j=0; j<fields.length; j+=2) {
String field = fields[j]; String field = fields[j];
String val = fields[j+1]; String val = fields[j+1];
Field f = schema.getField(field).createField(val, 1.0f); Fieldable f = schema.getField(field).createField(val, 1.0f);
add.doc.add(f); add.doc.add(f);
} }
} }