public abstract class AbstractSpatialFieldType<T extends SpatialStrategy> extends FieldType implements SpatialQueryable
SpatialStrategy.FieldType.DefaultAnalyzer, FieldType.MultiValueSelector| Modifier and Type | Field and Description |
|---|---|
protected SpatialArgsParser |
argsParser |
protected org.locationtech.spatial4j.context.SpatialContext |
ctx |
static String |
DISTANCE |
protected DistanceUnits |
distanceUnits |
static String |
FILTER_PARAM
A local-param boolean that can be set to false to only return the
FunctionQuery (score), and thus not do filtering.
|
static String |
FORMAT
Optional param to pick the string conversion
|
static String |
NONE |
static String |
RECIP_DISTANCE |
static String |
SCORE_PARAM
A local-param with one of "none" (default), "distance", "recipDistance" or supported values in (
DistanceUnits.getSupportedUnits(). |
protected org.locationtech.spatial4j.io.ShapeReader |
shapeReader |
protected org.locationtech.spatial4j.io.ShapeWriter |
shapeWriter |
protected Set<String> |
supportedScoreModes |
ANALYZER, args, AUTO_GENERATE_PHRASE_QUERIES, CHAR_FILTER, CHAR_FILTERS, CLASS_NAME, docValuesFormat, ENABLE_GRAPH_QUERIES, falseProperties, FILTER, FILTERS, INDEX, INDEX_ANALYZER, MULTI_TERM, MULTI_TERM_ANALYZER, POLY_FIELD_SEPARATOR, postingsFormat, properties, QUERY, QUERY_ANALYZER, similarity, SIMILARITY, similarityFactory, SYNONYM_QUERY_STYLE, TOKENIZER, trueProperties, TYPE, TYPE_NAME, typeNameBINARY, DOC_VALUES, INDEXED, LARGE_FIELD, MULTIVALUED, OMIT_NORMS, OMIT_POSITIONS, OMIT_TF_POSITIONS, REQUIRED, SORT_MISSING_FIRST, SORT_MISSING_LAST, STORE_OFFSETS, STORE_TERMOFFSETS, STORE_TERMPAYLOADS, STORE_TERMPOSITIONS, STORE_TERMVECTORS, STORED, TOKENIZED, UNINVERTIBLE, USE_DOCVALUES_AS_STORED| Modifier | Constructor and Description |
|---|---|
protected |
AbstractSpatialFieldType() |
protected |
AbstractSpatialFieldType(Set<String> moreScoreModes) |
| Modifier and Type | Method and Description |
|---|---|
Field |
createField(SchemaField field,
Object val)
Used for adding a document when a field needs to be created from a
type and a string.
|
List<IndexableField> |
createFields(SchemaField field,
Object val)
Given a
SchemaField, create one or more IndexableField instances |
Query |
createSpatialQuery(QParser parser,
SpatialOptions options)
Implemented for compatibility with geofilt & bbox query parsers:
SpatialQueryable. |
DistanceUnits |
getDistanceUnits() |
Query |
getFieldQuery(QParser parser,
SchemaField field,
String externalVal)
Returns a Query instance for doing searches against a field.
|
protected Query |
getQueryFromSpatialArgs(QParser parser,
SchemaField field,
SpatialArgs spatialArgs) |
Query |
getRangeQuery(QParser parser,
SchemaField field,
String part1,
String part2,
boolean minInclusive,
boolean maxInclusive)
Returns a Query instance for doing range searches on this field type.
|
SortField |
getSortField(SchemaField field,
boolean top)
Returns the SortField instance that should be used to sort fields
of this type.
|
org.locationtech.spatial4j.context.SpatialContext |
getSpatialContext() |
double |
getSphereRadius() |
protected String |
getStoredValue(org.locationtech.spatial4j.shape.Shape shape,
String shapeStr)
Called by
createFields(SchemaField, Object) to get the stored value. |
T |
getStrategy(String fieldName)
Gets the cached strategy for this field, creating it if necessary
via
newSpatialStrategy(String). |
Set<String> |
getSupportedScoreModes()
The set of values supported for the score local-param.
|
UninvertingReader.Type |
getUninversionType(SchemaField sf)
If DocValues is not enabled for a field, but it's indexed, docvalues can be constructed
on the fly (uninverted, aka fieldcache) on the first request to sort, facet, etc.
|
ValueSource |
getValueSource(SchemaField field,
QParser parser)
called to get the default value source (normally, from the
Lucene FieldCache.)
|
protected DoubleValuesSource |
getValueSourceFromSpatialArgs(QParser parser,
SchemaField field,
SpatialArgs spatialArgs,
String score,
T strategy) |
protected void |
init(IndexSchema schema,
Map<String,String> args)
subclasses should initialize themselves with the args provided
and remove valid arguments.
|
boolean |
isPolyField()
A "polyField" is a FieldType that can produce more than one IndexableField instance for a single value, via the
FieldType.createFields(org.apache.solr.schema.SchemaField, Object) method. |
protected SpatialArgsParser |
newSpatialArgsParser() |
protected abstract T |
newSpatialStrategy(String fieldName)
Called from
getStrategy(String) upon first use by fieldName. |
DistanceUnits |
parseDistanceUnits(String str)
if
str is non-null, returns DistanceUnits.valueOf(String)
(which will return null if not found),
else returns distanceUnits (only null before initialized in init(). |
org.locationtech.spatial4j.shape.Shape |
parseShape(String str)
Create a
Shape from the input string |
protected SpatialArgs |
parseSpatialArgs(QParser parser,
String externalVal) |
String |
shapeToString(org.locationtech.spatial4j.shape.Shape shape)
Returns a String version of a shape to be used for the stored value.
|
void |
write(TextResponseWriter writer,
String name,
IndexableField f)
calls back to TextResponseWriter to write the field value
|
checkSchemaField, checkSupportsDocValues, createField, getAnalyzerProperties, getClassArg, getDefaultMultiValueSelectorForSort, getDocValuesFormat, getIndexAnalyzer, getNamedPropertyValues, getNonFieldPropertyArgs, getNumberType, getNumericSort, getPostingsFormat, getPrefixQuery, getQueryAnalyzer, getRewriteMethod, getSetQuery, getSimilarity, getSimilarityFactory, getSingleValueSource, getSortedNumericSortField, getSortedSetSortField, getSortField, getStringSort, getTypeName, hasProperty, indexedToReadable, indexedToReadable, isExplicitAnalyzer, isExplicitQueryAnalyzer, isMultiValued, isPointField, isTokenized, isUtf8Field, marshalBase64SortValue, marshalSortValue, marshalStringSortValue, multiValuedFieldCache, readableToIndexed, readableToIndexed, restrictProps, setArgs, setIndexAnalyzer, setIsExplicitAnalyzer, setIsExplicitQueryAnalyzer, setQueryAnalyzer, setSimilarity, storedToIndexed, storedToReadable, supportsAnalyzers, toExternal, toInternal, toNativeType, toObject, toObject, toString, unmarshalBase64SortValue, unmarshalSortValue, unmarshalStringSortValue, useDocValuesAsStored, writepublic static final String SCORE_PARAM
DistanceUnits.getSupportedUnits().public static final String FILTER_PARAM
public static final String DISTANCE
public static final String RECIP_DISTANCE
public static final String NONE
public static final String FORMAT
protected org.locationtech.spatial4j.context.SpatialContext ctx
protected SpatialArgsParser argsParser
protected org.locationtech.spatial4j.io.ShapeWriter shapeWriter
protected org.locationtech.spatial4j.io.ShapeReader shapeReader
protected DistanceUnits distanceUnits
protected void init(IndexSchema schema, Map<String,String> args)
FieldTypepublic DistanceUnits parseDistanceUnits(String str)
str is non-null, returns DistanceUnits.valueOf(String)
(which will return null if not found),
else returns distanceUnits (only null before initialized in init().str - maybe nullprotected SpatialArgsParser newSpatialArgsParser()
public final Field createField(SchemaField field, Object val)
FieldTypeBy default, the indexed value is the same as the stored value (taken from toInternal()). Having a different representation for external, internal, and indexed would present quite a few problems given the current Lucene architecture. An analyzer for adding docs would need to translate internal->indexed while an analyzer for querying would need to translate external->indexed.
The only other alternative to having internal==indexed would be to have internal==external. In this case, toInternal should convert to the indexed representation, toExternal() should do nothing, and createField() should *not* call toInternal, but use the external value and set tokenized=true to get Lucene to convert to the internal(indexed) form.
:TODO: clean up and clarify this explanation.createField in class FieldTypeFieldType.toInternal(java.lang.String)public UninvertingReader.Type getUninversionType(SchemaField sf)
FieldTypeIf DocValues is not enabled for a field, but it's indexed, docvalues can be constructed on the fly (uninverted, aka fieldcache) on the first request to sort, facet, etc. This specifies the structure to use.
This method will not be used if the field is (effectively) uninvertible="false"
getUninversionType in class FieldTypesf - field instancenull (to disallow uninversion for the field)SchemaField.isUninvertible()public List<IndexableField> createFields(SchemaField field, Object val)
FieldTypeSchemaField, create one or more IndexableField instancescreateFields in class FieldTypefield - the SchemaFieldval - The value to add to the fieldIndexableFieldFieldType.createField(SchemaField, Object),
FieldType.isPolyField()protected String getStoredValue(org.locationtech.spatial4j.shape.Shape shape, String shapeStr)
createFields(SchemaField, Object) to get the stored value.public org.locationtech.spatial4j.shape.Shape parseShape(String str)
Shape from the input stringpublic String shapeToString(org.locationtech.spatial4j.shape.Shape shape)
format={WKT|GeoJSON}protected abstract T newSpatialStrategy(String fieldName)
getStrategy(String) upon first use by fieldName. }public final boolean isPolyField()
FieldTypeFieldType.createFields(org.apache.solr.schema.SchemaField, Object) method. This is useful
when hiding the implementation details of a field from the Solr end user. For instance, a spatial point may be represented by multiple different fields.isPolyField in class FieldTypeFieldType.createFields(org.apache.solr.schema.SchemaField, Object) method may return more than one fieldpublic Query createSpatialQuery(QParser parser, SpatialOptions options)
SpatialQueryable.createSpatialQuery in interface SpatialQueryablepublic Query getRangeQuery(QParser parser, SchemaField field, String part1, String part2, boolean minInclusive, boolean maxInclusive)
FieldTypeSolrQueryParser
currently passes part1 and part2 as null if they are '*' respectively. minInclusive and maxInclusive are both true
currently by SolrQueryParser but that may change in the future. Also, other QueryParser implementations may have
different semantics.
Sub-classes should override this method to provide their own range query implementation. They should strive to handle nulls in part1 and/or part2 as well as unequal minInclusive and maxInclusive parameters gracefully.
getRangeQuery in class FieldTypeparser - the QParser calling the methodfield - the schema fieldpart1 - the lower boundary of the range, nulls are allowed.part2 - the upper boundary of the range, nulls are allowedminInclusive - whether the minimum of the range is inclusive or notmaxInclusive - whether the maximum of the range is inclusive or notpublic ValueSource getValueSource(SchemaField field, QParser parser)
FieldTypegetValueSource in class FieldTypepublic Query getFieldQuery(QParser parser, SchemaField field, String externalVal)
FieldTypegetFieldQuery in class FieldTypeparser - The QParser calling the methodfield - The SchemaField of the field to searchexternalVal - The String representation of the value to searchQuery instance. This implementation returns a TermQuery but overriding queries may notprotected SpatialArgs parseSpatialArgs(QParser parser, String externalVal)
protected Query getQueryFromSpatialArgs(QParser parser, SchemaField field, SpatialArgs spatialArgs)
public double getSphereRadius()
getSphereRadius in interface SpatialQueryablepublic Set<String> getSupportedScoreModes()
protected DoubleValuesSource getValueSourceFromSpatialArgs(QParser parser, SchemaField field, SpatialArgs spatialArgs, String score, T strategy)
public T getStrategy(String fieldName)
newSpatialStrategy(String).fieldName - Mandatory reference to the field namepublic org.locationtech.spatial4j.context.SpatialContext getSpatialContext()
public void write(TextResponseWriter writer, String name, IndexableField f) throws IOException
FieldTypewrite in class FieldTypeIOExceptionpublic SortField getSortField(SchemaField field, boolean top)
FieldTypepublic DistanceUnits getDistanceUnits()
Copyright © 2000-2019 Apache Software Foundation. All Rights Reserved.