package hu.bme.mit.incquery.cep.runtime.evaluation.queries; import hu.bme.mit.incquery.cep.metamodels.internalsm.Transition; import java.util.Arrays; import java.util.List; import org.eclipse.incquery.patternlanguage.patternLanguage.Pattern; import org.eclipse.incquery.runtime.api.IPatternMatch; import org.eclipse.incquery.runtime.api.impl.BasePatternMatch; import org.eclipse.incquery.runtime.exception.IncQueryException; /** * Pattern-specific match representation of the hu.bme.mit.incquery.cep.runtime.evaluation.queries.transition pattern, * to be used in conjunction with {@link TransitionMatcher}. * * <p>Class fields correspond to parameters of the pattern. Fields with value null are considered unassigned. * Each instance is a (possibly partial) substitution of pattern parameters, * usable to represent a match of the pattern in the result of a query, * or to specify the bound (fixed) input parameters when issuing a query. * * @see TransitionMatcher * @see TransitionProcessor * */ @SuppressWarnings("all") public abstract class TransitionMatch extends BasePatternMatch { private Transition fT; private static List<String> parameterNames = makeImmutableList("t"); private TransitionMatch(final Transition pT) { this.fT = pT; } @Override public Object get(final String parameterName) { if ("t".equals(parameterName)) return this.fT; return null; } public Transition getT() { return this.fT; } @Override public boolean set(final String parameterName, final Object newValue) { if (!isMutable()) throw new java.lang.UnsupportedOperationException(); if ("t".equals(parameterName) ) { this.fT = (hu.bme.mit.incquery.cep.metamodels.internalsm.Transition) newValue; return true; } return false; } public void setT(final Transition pT) { if (!isMutable()) throw new java.lang.UnsupportedOperationException(); this.fT = pT; } @Override public String patternName() { return "hu.bme.mit.incquery.cep.runtime.evaluation.queries.transition"; } @Override public List<String> parameterNames() { return TransitionMatch.parameterNames; } @Override public Object[] toArray() { return new Object[]{fT}; } @Override public String prettyPrint() { StringBuilder result = new StringBuilder(); result.append("\"t\"=" + prettyPrintValue(fT)); return result.toString(); } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((fT == null) ? 0 : fT.hashCode()); return result; } @Override public boolean equals(final Object obj) { if (this == obj) return true; if (!(obj instanceof TransitionMatch)) { // this should be infrequent if (obj == null) return false; if (!(obj instanceof IPatternMatch)) return false; IPatternMatch otherSig = (IPatternMatch) obj; if (!pattern().equals(otherSig.pattern())) return false; return Arrays.deepEquals(toArray(), otherSig.toArray()); } TransitionMatch other = (TransitionMatch) obj; if (fT == null) {if (other.fT != null) return false;} else if (!fT.equals(other.fT)) return false; return true; } @Override public Pattern pattern() { try { return TransitionMatcher.querySpecification().getPattern(); } catch (IncQueryException ex) { // This cannot happen, as the match object can only be instantiated if the query specification exists throw new IllegalStateException (ex); } } @SuppressWarnings("all") static final class Mutable extends TransitionMatch { Mutable(final Transition pT) { super(pT); } @Override public boolean isMutable() { return true; } } @SuppressWarnings("all") static final class Immutable extends TransitionMatch { Immutable(final Transition pT) { super(pT); } @Override public boolean isMutable() { return false; } } }