Class IntersectBlockReader.AutomatonNextTermCalculator
java.lang.Object
org.apache.lucene.codecs.uniformsplit.IntersectBlockReader.AutomatonNextTermCalculator
- Enclosing class:
- IntersectBlockReader
This is mostly a copy of AutomatonTermsEnum. Since it's an inner class, the outer class can
 call methods that ATE does not expose. It'd be nice if ATE's logic could be more extensible.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected shortprotected booleanprotected final BytesRefprotected final IntsRefBuilderprotected final BytesRefBuilderprotected final Transitionprotected short[]
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected intbacktrack(int position) Attempts to backtrack thru the string after encountering a dead end at some given position.protected booleanisLinearState(BytesRef term) True if the current state of the automata is best iterated linearly (without seeking).protected BytesRefnextSeekTerm(BytesRef term) protected booleanIncrements the byte buffer to the next String in binary order after s that will not put the machine into a reject state.protected booleannextString(int state, int position) Returns the next String in lexicographic order that will not put the machine into a reject state.protected voidsetLinear(int position) Sets the enum to operate in linear fashion, as we have found a looping transition at position: we set an upper bound and act like a TermRangeQuery for this portion of the term space.
- 
Field Details- 
visitedprotected short[] visited
- 
curGenprotected short curGen
- 
seekBytesRef
- 
linearprotected boolean linear
- 
linearUpperBound
- 
transition
- 
savedStates
 
- 
- 
Constructor Details- 
AutomatonNextTermCalculator
 
- 
- 
Method Details- 
isLinearStateTrue if the current state of the automata is best iterated linearly (without seeking).
- 
nextSeekTerm- See Also:
 
- 
setLinearprotected void setLinear(int position) Sets the enum to operate in linear fashion, as we have found a looping transition at position: we set an upper bound and act like a TermRangeQuery for this portion of the term space.
- 
nextStringprotected boolean nextString()Increments the byte buffer to the next String in binary order after s that will not put the machine into a reject state. If such a string does not exist, returns false.The correctness of this method depends upon the automaton being deterministic, and having no transitions to dead states. - Returns:
- true if more possible solutions exist for the DFA
 
- 
nextStringprotected boolean nextString(int state, int position) Returns the next String in lexicographic order that will not put the machine into a reject state.This method traverses the DFA from the given position in the String, starting at the given state. If this cannot satisfy the machine, returns false. This method will walk the minimal path, in lexicographic order, as long as possible. If this method returns false, then there might still be more solutions, it is necessary to backtrack to find out. - Parameters:
- state- current non-reject state
- position- useful portion of the string
- Returns:
- true if more possible solutions exist for the DFA from this position
 
- 
backtrackprotected int backtrack(int position) Attempts to backtrack thru the string after encountering a dead end at some given position. Returns false if no more possible strings can match.- Parameters:
- position- current position in the input String
- Returns:
- position >= 0if more possible solutions exist for the DFA
 
 
-