/** */ package hu.bme.mit.inf.dslreasoner.viatra2logic.viatra2logicannotations.util; import hu.bme.mit.inf.dslreasoner.logic.model.logicproblem.Annotation; import hu.bme.mit.inf.dslreasoner.logic.model.logicproblem.AssertionAnnotation; import hu.bme.mit.inf.dslreasoner.logic.model.logicproblem.RelationAnnotation; import hu.bme.mit.inf.dslreasoner.viatra2logic.viatra2logicannotations.*; import org.eclipse.emf.ecore.EObject; import org.eclipse.emf.ecore.EPackage; import org.eclipse.emf.ecore.util.Switch; /** * * The Switch for the model's inheritance hierarchy. * It supports the call {@link #doSwitch(EObject) doSwitch(object)} * to invoke the caseXXX method for each class of the model, * starting with the actual class of the object * and proceeding up the inheritance hierarchy * until a non-null result is returned, * which is the result of the switch. * * @see hu.bme.mit.inf.dslreasoner.viatra2logic.viatra2logicannotations.Viatra2LogicAnnotationsPackage * @generated */ public class Viatra2LogicAnnotationsSwitch extends Switch { /** * The cached model package * * * @generated */ protected static Viatra2LogicAnnotationsPackage modelPackage; /** * Creates an instance of the switch. * * * @generated */ public Viatra2LogicAnnotationsSwitch() { if (modelPackage == null) { modelPackage = Viatra2LogicAnnotationsPackage.eINSTANCE; } } /** * Checks whether this is a switch for the given package. * * * @param ePackage the package in question. * @return whether this is a switch for the given package. * @generated */ @Override protected boolean isSwitchFor(EPackage ePackage) { return ePackage == modelPackage; } /** * Calls caseXXX for each class of the model until one returns a non null result; it yields that result. * * * @return the first non-null result returned by a caseXXX call. * @generated */ @Override protected T doSwitch(int classifierID, EObject theEObject) { switch (classifierID) { case Viatra2LogicAnnotationsPackage.TRANSFOMED_VIATRA_QUERY: { TransfomedViatraQuery transfomedViatraQuery = (TransfomedViatraQuery)theEObject; T result = caseTransfomedViatraQuery(transfomedViatraQuery); if (result == null) result = caseRelationAnnotation(transfomedViatraQuery); if (result == null) result = caseAnnotation(transfomedViatraQuery); if (result == null) result = defaultCase(theEObject); return result; } case Viatra2LogicAnnotationsPackage.TRANSFORMED_VIATRA_WELLFORMEDNESS_CONSTRAINT: { TransformedViatraWellformednessConstraint transformedViatraWellformednessConstraint = (TransformedViatraWellformednessConstraint)theEObject; T result = caseTransformedViatraWellformednessConstraint(transformedViatraWellformednessConstraint); if (result == null) result = caseAssertionAnnotation(transformedViatraWellformednessConstraint); if (result == null) result = caseAnnotation(transformedViatraWellformednessConstraint); if (result == null) result = defaultCase(theEObject); return result; } case Viatra2LogicAnnotationsPackage.DEFINED_BY_DERIVED_FEATURE: { DefinedByDerivedFeature definedByDerivedFeature = (DefinedByDerivedFeature)theEObject; T result = caseDefinedByDerivedFeature(definedByDerivedFeature); if (result == null) result = caseRelationAnnotation(definedByDerivedFeature); if (result == null) result = caseAnnotation(definedByDerivedFeature); if (result == null) result = defaultCase(theEObject); return result; } case Viatra2LogicAnnotationsPackage.VARIABLE_MAPPING: { VariableMapping variableMapping = (VariableMapping)theEObject; T result = caseVariableMapping(variableMapping); if (result == null) result = defaultCase(theEObject); return result; } default: return defaultCase(theEObject); } } /** * Returns the result of interpreting the object as an instance of 'Transfomed Viatra Query'. * * This implementation returns null; * returning a non-null result will terminate the switch. * * @param object the target of the switch. * @return the result of interpreting the object as an instance of 'Transfomed Viatra Query'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseTransfomedViatraQuery(TransfomedViatraQuery object) { return null; } /** * Returns the result of interpreting the object as an instance of 'Transformed Viatra Wellformedness Constraint'. * * This implementation returns null; * returning a non-null result will terminate the switch. * * @param object the target of the switch. * @return the result of interpreting the object as an instance of 'Transformed Viatra Wellformedness Constraint'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseTransformedViatraWellformednessConstraint(TransformedViatraWellformednessConstraint object) { return null; } /** * Returns the result of interpreting the object as an instance of 'Defined By Derived Feature'. * * This implementation returns null; * returning a non-null result will terminate the switch. * * @param object the target of the switch. * @return the result of interpreting the object as an instance of 'Defined By Derived Feature'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseDefinedByDerivedFeature(DefinedByDerivedFeature object) { return null; } /** * Returns the result of interpreting the object as an instance of 'Variable Mapping'. * * This implementation returns null; * returning a non-null result will terminate the switch. * * @param object the target of the switch. * @return the result of interpreting the object as an instance of 'Variable Mapping'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseVariableMapping(VariableMapping object) { return null; } /** * Returns the result of interpreting the object as an instance of 'Annotation'. * * This implementation returns null; * returning a non-null result will terminate the switch. * * @param object the target of the switch. * @return the result of interpreting the object as an instance of 'Annotation'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseAnnotation(Annotation object) { return null; } /** * Returns the result of interpreting the object as an instance of 'Relation Annotation'. * * This implementation returns null; * returning a non-null result will terminate the switch. * * @param object the target of the switch. * @return the result of interpreting the object as an instance of 'Relation Annotation'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseRelationAnnotation(RelationAnnotation object) { return null; } /** * Returns the result of interpreting the object as an instance of 'Assertion Annotation'. * * This implementation returns null; * returning a non-null result will terminate the switch. * * @param object the target of the switch. * @return the result of interpreting the object as an instance of 'Assertion Annotation'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseAssertionAnnotation(AssertionAnnotation object) { return null; } /** * Returns the result of interpreting the object as an instance of 'EObject'. * * This implementation returns null; * returning a non-null result will terminate the switch, but this is the last case anyway. * * @param object the target of the switch. * @return the result of interpreting the object as an instance of 'EObject'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) * @generated */ @Override public T defaultCase(EObject object) { return null; } } //Viatra2LogicAnnotationsSwitch