Class PredictionContext
- java.lang.Object
- 
- org.antlr.v4.runtime.atn.PredictionContext
 
- 
- Direct Known Subclasses:
- ArrayPredictionContext,- SingletonPredictionContext
 
 public abstract class PredictionContext extends Object 
- 
- 
Field SummaryFields Modifier and Type Field Description intcachedHashCodeStores the computed hash code of thisPredictionContext.static intEMPTY_RETURN_STATERepresents$in an array in full context mode, when$doesn't mean wildcard:$ + x = [$,x].intid
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedPredictionContext(int cachedHashCode)
 - 
Method Summary
 
- 
- 
- 
Field Detail- 
EMPTY_RETURN_STATEpublic static final int EMPTY_RETURN_STATE Represents$in an array in full context mode, when$doesn't mean wildcard:$ + x = [$,x]. Here,$=EMPTY_RETURN_STATE.- See Also:
- Constant Field Values
 
 - 
idpublic final int id 
 - 
cachedHashCodepublic final int cachedHashCode Stores the computed hash code of thisPredictionContext. The hash code is computed in parts to match the following reference algorithm.private int referenceHashCode() { int hash =MurmurHash.initialize(INITIAL_HASH); for (int i = 0; i <size(); i++) { hash =MurmurHash.update(hash,getParent(i)); } for (int i = 0; i <size(); i++) { hash =MurmurHash.update(hash,getReturnState(i)); } hash =MurmurHash.finish(hash, 2 *size()); return hash; }
 
- 
 - 
Method Detail- 
fromRuleContextpublic static PredictionContext fromRuleContext(ATN atn, RuleContext outerContext) Convert aRuleContexttree to aPredictionContextgraph. ReturnEmptyPredictionContext.InstanceifouterContextis empty or null.
 - 
sizepublic abstract int size() 
 - 
getParentpublic abstract PredictionContext getParent(int index) 
 - 
getReturnStatepublic abstract int getReturnState(int index) 
 - 
isEmptypublic boolean isEmpty() This means only theEmptyPredictionContext.Instance(wildcard? not sure) context is in set.
 - 
hasEmptyPathpublic boolean hasEmptyPath() 
 - 
calculateEmptyHashCodeprotected static int calculateEmptyHashCode() 
 - 
calculateHashCodeprotected static int calculateHashCode(PredictionContext parent, int returnState) 
 - 
calculateHashCodeprotected static int calculateHashCode(PredictionContext[] parents, int[] returnStates) 
 - 
mergepublic static PredictionContext merge(PredictionContext a, PredictionContext b, boolean rootIsWildcard, DoubleKeyMap<PredictionContext,PredictionContext,PredictionContext> mergeCache) 
 - 
mergeSingletonspublic static PredictionContext mergeSingletons(SingletonPredictionContext a, SingletonPredictionContext b, boolean rootIsWildcard, DoubleKeyMap<PredictionContext,PredictionContext,PredictionContext> mergeCache) Merge twoSingletonPredictionContextinstances.Stack tops equal, parents merge is same; return left graph. 
 Same stack top, parents differ; merge parents giving array node, then remainders of those graphs. A new root node is created to point to the merged parents. 
 Different stack tops pointing to same parent. Make array node for the root where both element in the root point to the same (original) parent. 
 Different stack tops pointing to different parents. Make array node for the root where each element points to the corresponding original parent. 
 - Parameters:
- a- the first- SingletonPredictionContext
- b- the second- SingletonPredictionContext
- rootIsWildcard-- trueif this is a local-context merge, otherwise false to indicate a full-context merge
- mergeCache-
 
 - 
mergeRootpublic static PredictionContext mergeRoot(SingletonPredictionContext a, SingletonPredictionContext b, boolean rootIsWildcard) Handle case where at least one ofaorbisEmptyPredictionContext.Instance. In the following diagrams, the symbol$is used to representEmptyPredictionContext.Instance.Local-Context MergesThese local-context merge operations are used when rootIsWildcardis true.EmptyPredictionContext.Instanceis superset of any graph; returnEmptyPredictionContext.Instance.
 EmptyPredictionContext.Instanceand anything is#EMPTY, so merged parent is#EMPTY; return left graph.
 Special case of last merge if local context. 
 Full-Context MergesThese full-context merge operations are used when rootIsWildcardis false.Must keep all contexts; EmptyPredictionContext.Instancein array is a special value (and null parent).
 - Parameters:
- a- the first- SingletonPredictionContext
- b- the second- SingletonPredictionContext
- rootIsWildcard-- trueif this is a local-context merge, otherwise false to indicate a full-context merge
 
 - 
mergeArrayspublic static PredictionContext mergeArrays(ArrayPredictionContext a, ArrayPredictionContext b, boolean rootIsWildcard, DoubleKeyMap<PredictionContext,PredictionContext,PredictionContext> mergeCache) Merge twoArrayPredictionContextinstances.Different tops, different parents. 
 Shared top, same parents. 
 Shared top, different parents. 
 Shared top, all shared parents. 
 Equal tops, merge parents and reduce top to SingletonPredictionContext.
 
 - 
combineCommonParentsprotected static void combineCommonParents(PredictionContext[] parents) Make pass over all Mparents; merge anyequals()ones.
 - 
toDOTStringpublic static String toDOTString(PredictionContext context) 
 - 
getCachedContextpublic static PredictionContext getCachedContext(PredictionContext context, PredictionContextCache contextCache, IdentityHashMap<PredictionContext,PredictionContext> visited) 
 - 
getAllContextNodespublic static List<PredictionContext> getAllContextNodes(PredictionContext context) 
 - 
getAllContextNodes_public static void getAllContextNodes_(PredictionContext context, List<PredictionContext> nodes, Map<PredictionContext,PredictionContext> visited) 
 - 
toStringpublic String toString(Recognizer<?,?> recog) 
 - 
toStringspublic String[] toStrings(Recognizer<?,?> recognizer, int currentState) 
 - 
toStringspublic String[] toStrings(Recognizer<?,?> recognizer, PredictionContext stop, int currentState) 
 
- 
 
-