Class TSTLookup
- java.lang.Object
-
- org.apache.lucene.search.suggest.Lookup
-
- org.apache.lucene.search.suggest.tst.TSTLookup
-
public class TSTLookup extends Lookup
Suggest implementation based on a Ternary Search Tree- See Also:
TSTAutocomplete
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.apache.lucene.search.suggest.Lookup
Lookup.LookupPriorityQueue, Lookup.LookupResult
-
-
Field Summary
-
Fields inherited from class org.apache.lucene.search.suggest.Lookup
CHARSEQUENCE_COMPARATOR
-
-
Constructor Summary
Constructors Constructor Description TSTLookup()
Creates a new TSTLookup with an empty Ternary Search Tree.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
add(CharSequence key, Object value)
Adds a new node ifkey
already exists, otherwise replaces its value.void
build(InputIterator tfit)
Builds up a new internalLookup
representation based on the givenInputIterator
.Object
get(CharSequence key)
Returns the value for the specified key, or null if the key does not exist.long
getCount()
Get the number of entries the lookup was built withboolean
load(DataInput input)
Discard current lookup data and load it from a previously saved copy.List<Lookup.LookupResult>
lookup(CharSequence key, boolean onlyMorePopular, int num)
Look up a key and return possible completion for this key.long
sizeInBytes()
Returns byte size of the underlying TSTboolean
store(DataOutput output)
Persist the constructed lookup data to a directory.
-
-
-
Constructor Detail
-
TSTLookup
public TSTLookup()
Creates a new TSTLookup with an empty Ternary Search Tree.- See Also:
build(InputIterator)
-
-
Method Detail
-
build
public void build(InputIterator tfit) throws IOException
Description copied from class:Lookup
Builds up a new internalLookup
representation based on the givenInputIterator
. The implementation might re-sort the data internally.- Specified by:
build
in classLookup
- Throws:
IOException
-
add
public boolean add(CharSequence key, Object value)
Adds a new node ifkey
already exists, otherwise replaces its value.This method always returns true.
-
get
public Object get(CharSequence key)
Returns the value for the specified key, or null if the key does not exist.
-
lookup
public List<Lookup.LookupResult> lookup(CharSequence key, boolean onlyMorePopular, int num)
Description copied from class:Lookup
Look up a key and return possible completion for this key.- Specified by:
lookup
in classLookup
- Parameters:
key
- lookup key. Depending on the implementation this may be a prefix, misspelling, or even infix.onlyMorePopular
- return only more popular resultsnum
- maximum number of results to return- Returns:
- a list of possible completions, with their relative weight (e.g. popularity)
-
store
public boolean store(DataOutput output) throws IOException
Description copied from class:Lookup
Persist the constructed lookup data to a directory. Optional operation.- Specified by:
store
in classLookup
- Parameters:
output
-DataOutput
to write the data to.- Returns:
- true if successful, false if unsuccessful or not supported.
- Throws:
IOException
- when fatal IO error occurs.
-
load
public boolean load(DataInput input) throws IOException
Description copied from class:Lookup
Discard current lookup data and load it from a previously saved copy. Optional operation.- Specified by:
load
in classLookup
- Parameters:
input
- theDataInput
to load the lookup data.- Returns:
- true if completed successfully, false if unsuccessful or not supported.
- Throws:
IOException
- when fatal IO error occurs.
-
sizeInBytes
public long sizeInBytes()
Returns byte size of the underlying TST- Specified by:
sizeInBytes
in classLookup
- Returns:
- ram size of the lookup implementation in bytes
-
-