public class EquivalentStatesMatcher extends BaseMatcher<EquivalentStatesMatch>
Use the pattern matcher on a given model via on(ViatraQueryEngine)
,
e.g. in conjunction with ViatraQueryEngine#on(Notifier)
.
Matches of the pattern will be represented as EquivalentStatesMatch
.
Original source:
pattern
equivalentStates(transition1 : TypedTransition, transition2 : TypedTransition, preState : State, postState1 : State, postState2 : State) {
transition1 != transition2;
count find negativeTransition(transition1) ==
count find negativeTransition(transition2);
Transition.preState(transition1, preState);
Transition.preState(transition2, preState);
Transition.postState(transition1, postState1);
Transition.postState(transition2, postState2);
postState1 != postState2;
TypedTransition.guards(transition1, guard1);
TypedTransition.guards(transition2, guard2);
Guard.eventType.id(guard1, et1);
Guard.eventType.id(guard2, et2);
et1 == et2;
Automaton.states(automaton, preState);
Automaton.states(automaton, postState1);
Automaton.states(automaton, postState2);
}
EquivalentStatesMatch
,
EquivalentStatesProcessor
,
EquivalentStatesQuerySpecification
engine, querySpecification
Modifier and Type | Method and Description |
---|---|
protected EquivalentStatesMatch |
arrayToMatch(java.lang.Object[] match)
Converts the array representation of a pattern match to an immutable Match object.
|
protected EquivalentStatesMatch |
arrayToMatchMutable(java.lang.Object[] match)
Converts the array representation of a pattern match to a mutable Match object.
|
int |
countMatches(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState1,
State pPostState2)
Returns the number of all matches of the pattern that conform to the given fixed values of some parameters.
|
static EquivalentStatesMatcher |
create() |
void |
forEachMatch(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState1,
State pPostState2,
IMatchProcessor<? super EquivalentStatesMatch> processor)
Executes the given processor on each match of the pattern that conforms to the given fixed values of some parameters.
|
boolean |
forOneArbitraryMatch(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState1,
State pPostState2,
IMatchProcessor<? super EquivalentStatesMatch> processor)
Executes the given processor on an arbitrarily chosen match of the pattern that conforms to the given fixed values of some parameters.
|
java.util.Collection<EquivalentStatesMatch> |
getAllMatches(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState1,
State pPostState2)
Returns the set of all matches of the pattern that conform to the given fixed values of some parameters.
|
java.util.Set<State> |
getAllValuesOfpostState1()
Retrieve the set of values that occur in matches for postState1.
|
java.util.Set<State> |
getAllValuesOfpostState1(EquivalentStatesMatch partialMatch)
Retrieve the set of values that occur in matches for postState1.
|
java.util.Set<State> |
getAllValuesOfpostState1(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState2)
Retrieve the set of values that occur in matches for postState1.
|
java.util.Set<State> |
getAllValuesOfpostState2()
Retrieve the set of values that occur in matches for postState2.
|
java.util.Set<State> |
getAllValuesOfpostState2(EquivalentStatesMatch partialMatch)
Retrieve the set of values that occur in matches for postState2.
|
java.util.Set<State> |
getAllValuesOfpostState2(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState1)
Retrieve the set of values that occur in matches for postState2.
|
java.util.Set<State> |
getAllValuesOfpreState()
Retrieve the set of values that occur in matches for preState.
|
java.util.Set<State> |
getAllValuesOfpreState(EquivalentStatesMatch partialMatch)
Retrieve the set of values that occur in matches for preState.
|
java.util.Set<State> |
getAllValuesOfpreState(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPostState1,
State pPostState2)
Retrieve the set of values that occur in matches for preState.
|
java.util.Set<TypedTransition> |
getAllValuesOftransition1()
Retrieve the set of values that occur in matches for transition1.
|
java.util.Set<TypedTransition> |
getAllValuesOftransition1(EquivalentStatesMatch partialMatch)
Retrieve the set of values that occur in matches for transition1.
|
java.util.Set<TypedTransition> |
getAllValuesOftransition1(TypedTransition pTransition2,
State pPreState,
State pPostState1,
State pPostState2)
Retrieve the set of values that occur in matches for transition1.
|
java.util.Set<TypedTransition> |
getAllValuesOftransition2()
Retrieve the set of values that occur in matches for transition2.
|
java.util.Set<TypedTransition> |
getAllValuesOftransition2(EquivalentStatesMatch partialMatch)
Retrieve the set of values that occur in matches for transition2.
|
java.util.Set<TypedTransition> |
getAllValuesOftransition2(TypedTransition pTransition1,
State pPreState,
State pPostState1,
State pPostState2)
Retrieve the set of values that occur in matches for transition2.
|
EquivalentStatesMatch |
getOneArbitraryMatch(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState1,
State pPostState2)
Returns an arbitrarily chosen match of the pattern that conforms to the given fixed values of some parameters.
|
boolean |
hasMatch(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState1,
State pPostState2)
Indicates whether the given combination of specified pattern parameters constitute a valid pattern match,
under any possible substitution of the unspecified parameters (if any).
|
EquivalentStatesMatch |
newMatch(TypedTransition pTransition1,
TypedTransition pTransition2,
State pPreState,
State pPostState1,
State pPostState2)
Returns a new (partial) match.
|
static EquivalentStatesMatcher |
on(ViatraQueryEngine engine)
Initializes the pattern matcher within an existing VIATRA Query engine.
|
static IQuerySpecification<EquivalentStatesMatcher> |
querySpecification() |
protected java.util.Set<State> |
rawAccumulateAllValuesOfpostState1(java.lang.Object[] parameters)
Retrieve the set of values that occur in matches for postState1.
|
protected java.util.Set<State> |
rawAccumulateAllValuesOfpostState2(java.lang.Object[] parameters)
Retrieve the set of values that occur in matches for postState2.
|
protected java.util.Set<State> |
rawAccumulateAllValuesOfpreState(java.lang.Object[] parameters)
Retrieve the set of values that occur in matches for preState.
|
protected java.util.Set<TypedTransition> |
rawAccumulateAllValuesOftransition1(java.lang.Object[] parameters)
Retrieve the set of values that occur in matches for transition1.
|
protected java.util.Set<TypedTransition> |
rawAccumulateAllValuesOftransition2(java.lang.Object[] parameters)
Retrieve the set of values that occur in matches for transition2.
|
protected EquivalentStatesMatch |
tupleToMatch(Tuple t) |
countMatches, countMatches, emptyArray, forEachMatch, forEachMatch, forOneArbitraryMatch, forOneArbitraryMatch, getAllMatches, getAllMatches, getAllValues, getAllValues, getCapabilities, getEngine, getOneArbitraryMatch, getOneArbitraryMatch, getParameterNames, getPatternName, getPositionOfParameter, getSpecification, hasMatch, matchToArray, newEmptyMatch, newMatch, rawAccumulateAllValues, rawCountMatches, rawForEachMatch, rawForOneArbitraryMatch, rawGetAllMatches, rawGetAllValues, rawGetOneArbitraryMatch, rawHasMatch, setBackend
public static EquivalentStatesMatcher on(ViatraQueryEngine engine) throws ViatraQueryException
engine
- the existing VIATRA Query engine in which this matcher will be created.ViatraQueryException
- if an error occurs during pattern matcher creationpublic static EquivalentStatesMatcher create() throws ViatraQueryException
ViatraQueryException
- if an error occurs during pattern matcher creationpublic java.util.Collection<EquivalentStatesMatch> getAllMatches(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState1, State pPostState2)
pTransition1
- the fixed value of pattern parameter transition1, or null if not bound.pTransition2
- the fixed value of pattern parameter transition2, or null if not bound.pPreState
- the fixed value of pattern parameter preState, or null if not bound.pPostState1
- the fixed value of pattern parameter postState1, or null if not bound.pPostState2
- the fixed value of pattern parameter postState2, or null if not bound.public EquivalentStatesMatch getOneArbitraryMatch(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState1, State pPostState2)
pTransition1
- the fixed value of pattern parameter transition1, or null if not bound.pTransition2
- the fixed value of pattern parameter transition2, or null if not bound.pPreState
- the fixed value of pattern parameter preState, or null if not bound.pPostState1
- the fixed value of pattern parameter postState1, or null if not bound.pPostState2
- the fixed value of pattern parameter postState2, or null if not bound.public boolean hasMatch(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState1, State pPostState2)
pTransition1
- the fixed value of pattern parameter transition1, or null if not bound.pTransition2
- the fixed value of pattern parameter transition2, or null if not bound.pPreState
- the fixed value of pattern parameter preState, or null if not bound.pPostState1
- the fixed value of pattern parameter postState1, or null if not bound.pPostState2
- the fixed value of pattern parameter postState2, or null if not bound.public int countMatches(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState1, State pPostState2)
pTransition1
- the fixed value of pattern parameter transition1, or null if not bound.pTransition2
- the fixed value of pattern parameter transition2, or null if not bound.pPreState
- the fixed value of pattern parameter preState, or null if not bound.pPostState1
- the fixed value of pattern parameter postState1, or null if not bound.pPostState2
- the fixed value of pattern parameter postState2, or null if not bound.public void forEachMatch(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState1, State pPostState2, IMatchProcessor<? super EquivalentStatesMatch> processor)
pTransition1
- the fixed value of pattern parameter transition1, or null if not bound.pTransition2
- the fixed value of pattern parameter transition2, or null if not bound.pPreState
- the fixed value of pattern parameter preState, or null if not bound.pPostState1
- the fixed value of pattern parameter postState1, or null if not bound.pPostState2
- the fixed value of pattern parameter postState2, or null if not bound.processor
- the action that will process each pattern match.public boolean forOneArbitraryMatch(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState1, State pPostState2, IMatchProcessor<? super EquivalentStatesMatch> processor)
pTransition1
- the fixed value of pattern parameter transition1, or null if not bound.pTransition2
- the fixed value of pattern parameter transition2, or null if not bound.pPreState
- the fixed value of pattern parameter preState, or null if not bound.pPostState1
- the fixed value of pattern parameter postState1, or null if not bound.pPostState2
- the fixed value of pattern parameter postState2, or null if not bound.processor
- the action that will process the selected match.public EquivalentStatesMatch newMatch(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState1, State pPostState2)
The returned match will be immutable. Use BaseMatcher.newEmptyMatch()
to obtain a mutable match object.
pTransition1
- the fixed value of pattern parameter transition1, or null if not bound.pTransition2
- the fixed value of pattern parameter transition2, or null if not bound.pPreState
- the fixed value of pattern parameter preState, or null if not bound.pPostState1
- the fixed value of pattern parameter postState1, or null if not bound.pPostState2
- the fixed value of pattern parameter postState2, or null if not bound.protected java.util.Set<TypedTransition> rawAccumulateAllValuesOftransition1(java.lang.Object[] parameters)
public java.util.Set<TypedTransition> getAllValuesOftransition1()
public java.util.Set<TypedTransition> getAllValuesOftransition1(EquivalentStatesMatch partialMatch)
public java.util.Set<TypedTransition> getAllValuesOftransition1(TypedTransition pTransition2, State pPreState, State pPostState1, State pPostState2)
protected java.util.Set<TypedTransition> rawAccumulateAllValuesOftransition2(java.lang.Object[] parameters)
public java.util.Set<TypedTransition> getAllValuesOftransition2()
public java.util.Set<TypedTransition> getAllValuesOftransition2(EquivalentStatesMatch partialMatch)
public java.util.Set<TypedTransition> getAllValuesOftransition2(TypedTransition pTransition1, State pPreState, State pPostState1, State pPostState2)
protected java.util.Set<State> rawAccumulateAllValuesOfpreState(java.lang.Object[] parameters)
public java.util.Set<State> getAllValuesOfpreState()
public java.util.Set<State> getAllValuesOfpreState(EquivalentStatesMatch partialMatch)
public java.util.Set<State> getAllValuesOfpreState(TypedTransition pTransition1, TypedTransition pTransition2, State pPostState1, State pPostState2)
protected java.util.Set<State> rawAccumulateAllValuesOfpostState1(java.lang.Object[] parameters)
public java.util.Set<State> getAllValuesOfpostState1()
public java.util.Set<State> getAllValuesOfpostState1(EquivalentStatesMatch partialMatch)
public java.util.Set<State> getAllValuesOfpostState1(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState2)
protected java.util.Set<State> rawAccumulateAllValuesOfpostState2(java.lang.Object[] parameters)
public java.util.Set<State> getAllValuesOfpostState2()
public java.util.Set<State> getAllValuesOfpostState2(EquivalentStatesMatch partialMatch)
public java.util.Set<State> getAllValuesOfpostState2(TypedTransition pTransition1, TypedTransition pTransition2, State pPreState, State pPostState1)
protected EquivalentStatesMatch tupleToMatch(Tuple t)
tupleToMatch
in class BaseMatcher<EquivalentStatesMatch>
protected EquivalentStatesMatch arrayToMatch(java.lang.Object[] match)
BaseMatcher
arrayToMatch
in class BaseMatcher<EquivalentStatesMatch>
protected EquivalentStatesMatch arrayToMatchMutable(java.lang.Object[] match)
BaseMatcher
arrayToMatchMutable
in class BaseMatcher<EquivalentStatesMatch>
public static IQuerySpecification<EquivalentStatesMatcher> querySpecification() throws ViatraQueryException
ViatraQueryException
- if the pattern definition could not be loaded