package hu.bme.mit.incquery.cep.runtime.evaluation.queries; import hu.bme.mit.incquery.cep.metamodels.cep.AtomicEventPattern; import hu.bme.mit.incquery.cep.metamodels.internalsm.Guard; 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.guardAtomicPattern pattern, * to be used in conjunction with {@link GuardAtomicPatternMatcher}. * * <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 GuardAtomicPatternMatcher * @see GuardAtomicPatternProcessor * */ @SuppressWarnings("all") public abstract class GuardAtomicPatternMatch extends BasePatternMatch { private Guard fGuard; private AtomicEventPattern fAtomicPattern; private static List<String> parameterNames = makeImmutableList("guard", "atomicPattern"); private GuardAtomicPatternMatch(final Guard pGuard, final AtomicEventPattern pAtomicPattern) { this.fGuard = pGuard; this.fAtomicPattern = pAtomicPattern; } @Override public Object get(final String parameterName) { if ("guard".equals(parameterName)) return this.fGuard; if ("atomicPattern".equals(parameterName)) return this.fAtomicPattern; return null; } public Guard getGuard() { return this.fGuard; } public AtomicEventPattern getAtomicPattern() { return this.fAtomicPattern; } @Override public boolean set(final String parameterName, final Object newValue) { if (!isMutable()) throw new java.lang.UnsupportedOperationException(); if ("guard".equals(parameterName) ) { this.fGuard = (hu.bme.mit.incquery.cep.metamodels.internalsm.Guard) newValue; return true; } if ("atomicPattern".equals(parameterName) ) { this.fAtomicPattern = (hu.bme.mit.incquery.cep.metamodels.cep.AtomicEventPattern) newValue; return true; } return false; } public void setGuard(final Guard pGuard) { if (!isMutable()) throw new java.lang.UnsupportedOperationException(); this.fGuard = pGuard; } public void setAtomicPattern(final AtomicEventPattern pAtomicPattern) { if (!isMutable()) throw new java.lang.UnsupportedOperationException(); this.fAtomicPattern = pAtomicPattern; } @Override public String patternName() { return "hu.bme.mit.incquery.cep.runtime.evaluation.queries.guardAtomicPattern"; } @Override public List<String> parameterNames() { return GuardAtomicPatternMatch.parameterNames; } @Override public Object[] toArray() { return new Object[]{fGuard, fAtomicPattern}; } @Override public String prettyPrint() { StringBuilder result = new StringBuilder(); result.append("\"guard\"=" + prettyPrintValue(fGuard) + ", "); result.append("\"atomicPattern\"=" + prettyPrintValue(fAtomicPattern)); return result.toString(); } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((fGuard == null) ? 0 : fGuard.hashCode()); result = prime * result + ((fAtomicPattern == null) ? 0 : fAtomicPattern.hashCode()); return result; } @Override public boolean equals(final Object obj) { if (this == obj) return true; if (!(obj instanceof GuardAtomicPatternMatch)) { // 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()); } GuardAtomicPatternMatch other = (GuardAtomicPatternMatch) obj; if (fGuard == null) {if (other.fGuard != null) return false;} else if (!fGuard.equals(other.fGuard)) return false; if (fAtomicPattern == null) {if (other.fAtomicPattern != null) return false;} else if (!fAtomicPattern.equals(other.fAtomicPattern)) return false; return true; } @Override public Pattern pattern() { try { return GuardAtomicPatternMatcher.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 GuardAtomicPatternMatch { Mutable(final Guard pGuard, final AtomicEventPattern pAtomicPattern) { super(pGuard, pAtomicPattern); } @Override public boolean isMutable() { return true; } } @SuppressWarnings("all") static final class Immutable extends GuardAtomicPatternMatch { Immutable(final Guard pGuard, final AtomicEventPattern pAtomicPattern) { super(pGuard, pAtomicPattern); } @Override public boolean isMutable() { return false; } } }