Class Extensions
java.lang.Object
org.apache.lucene.queryparser.ext.Extensions
The 
Extensions class represents an extension mapping to associate ParserExtension
 instances with extension keys. An extension key is a string encoded into a Lucene standard query
 parser field symbol recognized by ExtendableQueryParser. The query parser passes each
 extension field token to splitExtensionField(String, String) to separate the extension
 key from the field identifier.
 In addition to the key to extension mapping this class also defines the field name overloading
 scheme. ExtendableQueryParser uses the given extension to split the actual field name and
 extension key by calling splitExtensionField(String, String). To change the order or the
 key / field name encoding scheme users can subclass Extensions to implement their own.
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic final recordThis class represents a generic pair.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final charThe default extension field delimiter character.
- 
Constructor SummaryConstructorsConstructorDescriptionCreates a newExtensionsinstance with theDEFAULT_EXTENSION_FIELD_DELIMITERas a delimiter character.Extensions(char extensionFieldDelimiter) Creates a newExtensionsinstance
- 
Method SummaryModifier and TypeMethodDescriptionvoidadd(String key, ParserExtension extension) Adds a newParserExtensioninstance associated with the given key.buildExtensionField(String extensionKey) Builds an extension field string from a given extension key and the default query field.buildExtensionField(String extensionKey, String field) Builds an extension field string from a given extension key and the extensions field.escapeExtensionField(String extfield) Escapes an extension field.final ParserExtensiongetExtension(String key) Returns theParserExtensioninstance for the given key ornullif no extension can be found for the key.charReturns the extension field delimitersplitExtensionField(String defaultField, String field) Splits a extension field and returns the field / extension part as aExtensions.Pair.
- 
Field Details- 
DEFAULT_EXTENSION_FIELD_DELIMITERpublic static final char DEFAULT_EXTENSION_FIELD_DELIMITERThe default extension field delimiter character. This constant is set to ':'- See Also:
 
 
- 
- 
Constructor Details- 
Extensionspublic Extensions()Creates a newExtensionsinstance with theDEFAULT_EXTENSION_FIELD_DELIMITERas a delimiter character.
- 
Extensionspublic Extensions(char extensionFieldDelimiter) Creates a newExtensionsinstance- Parameters:
- extensionFieldDelimiter- the extensions field delimiter character
 
 
- 
- 
Method Details- 
addAdds a newParserExtensioninstance associated with the given key.- Parameters:
- key- the parser extension key
- extension- the parser extension
 
- 
getExtensionReturns theParserExtensioninstance for the given key ornullif no extension can be found for the key.- Parameters:
- key- the extension key
- Returns:
- the ParserExtensioninstance for the given key ornullif no extension can be found for the key.
 
- 
getExtensionFieldDelimiterpublic char getExtensionFieldDelimiter()Returns the extension field delimiter- Returns:
- the extension field delimiter
 
- 
splitExtensionFieldSplits a extension field and returns the field / extension part as aExtensions.Pair. This method tries to split on the first occurrence of the extension field delimiter, if the delimiter is not present in the string the result will contain anullvalue for the extension key and the given field string as the field value. If the given extension field string contains no field identifier the result pair will carry the given default field as the field value.- Parameters:
- defaultField- the default query field
- field- the extension field string
- Returns:
- a Extensions.Pairwith the field name as theExtensions.Pair.curand the extension key as theExtensions.Pair.cud
 
- 
escapeExtensionFieldEscapes an extension field. The default implementation is equivalent toQueryParserBase.escape(String).- Parameters:
- extfield- the extension field identifier
- Returns:
- the extension field identifier with all special chars escaped with a backslash character.
 
- 
buildExtensionFieldBuilds an extension field string from a given extension key and the default query field. The default field and the key are delimited with the extension field delimiter character. This method makes no assumption about the order of the extension key and the field. By default the extension key is appended to the end of the returned string while the field is added to the beginning. Special Query characters are escaped in the result.Note: Extensionssubclasses must maintain the contract betweenbuildExtensionField(String)andsplitExtensionField(String, String)where the latter inverts the former.
- 
buildExtensionFieldBuilds an extension field string from a given extension key and the extensions field. The field and the key are delimited with the extension field delimiter character. This method makes no assumption about the order of the extension key and the field. By default the extension key is appended to the end of the returned string while the field is added to the beginning. Special Query characters are escaped in the result.Note: Extensionssubclasses must maintain the contract betweenbuildExtensionField(String, String)andsplitExtensionField(String, String)where the latter inverts the former.- Parameters:
- extensionKey- the extension key
- field- the field to apply the extension on.
- Returns:
- escaped extension field identifier
- See Also:
 
 
-