// Copyright 2012 Georg-August-Universität Göttingen, Germany // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package de.ugoe.cs.autoquest.tasktrees.nodeequality; import de.ugoe.cs.autoquest.tasktrees.treeifc.IEventTask; import de.ugoe.cs.autoquest.tasktrees.treeifc.ITaskTreeNode; /** *

* This rule identifies two task tree nodes as lexically equal, if they are both event tasks and * if their respective event types and targets equal. *

* * @author Patrick Harms */ public class EventTaskComparisonRule implements NodeComparisonRule { /* (non-Javadoc) * @see NodeComparisonRule#isApplicable(ITaskTreeNode, ITaskTreeNode) */ @Override public boolean isApplicable(ITaskTreeNode node1, ITaskTreeNode node2) { return (node1 instanceof IEventTask) && (node2 instanceof IEventTask); } /* (non-Javadoc) * @see NodeComparisonRule#areLexicallyEqual(ITaskTreeNode, ITaskTreeNode) */ @Override public boolean areLexicallyEqual(ITaskTreeNode node1, ITaskTreeNode node2) { IEventTask task1 = (IEventTask) node1; IEventTask task2 = (IEventTask) node2; return (task1.getEventType().equals(task2.getEventType()) && task1.getEventTarget().equals(task2.getEventTarget())); } /* (non-Javadoc) * @see NodeComparisonRule#areSyntacticallyEqual(ITaskTreeNode, ITaskTreeNode) */ @Override public boolean areSyntacticallyEqual(ITaskTreeNode node1, ITaskTreeNode node2) { return areLexicallyEqual(node1, node2); } /* (non-Javadoc) * @see NodeComparisonRule#areSemanticallyEqual(ITaskTreeNode, ITaskTreeNode) */ @Override public boolean areSemanticallyEqual(ITaskTreeNode node1, ITaskTreeNode node2) { return areLexicallyEqual(node1, node2); } @Override public NodeEquality compare(ITaskTreeNode node1, ITaskTreeNode node2) { if (areLexicallyEqual(node1, node2)) { return NodeEquality.LEXICALLY_EQUAL; } else { return NodeEquality.UNEQUAL; } } }