/** * Copyright (c) 2011 Cloudsmith Inc. and other contributors, as listed below. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Cloudsmith * */ package org.cloudsmith.geppetto.catalog.util; import org.cloudsmith.geppetto.catalog.*; import org.eclipse.emf.ecore.EObject; import org.eclipse.emf.ecore.EPackage; import org.eclipse.emf.ecore.util.Switch; /** * <!-- begin-user-doc --> * The <b>Switch</b> for the model's inheritance hierarchy. * It supports the call {@link #doSwitch(EObject) doSwitch(object)} to invoke the <code>caseXXX</code> 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. * <!-- end-user-doc --> * * @see org.cloudsmith.geppetto.catalog.CatalogPackage * @generated */ public class CatalogSwitch<T> extends Switch<T> { /** * The cached model package * <!-- begin-user-doc --> * <!-- end-user-doc --> * * @generated */ protected static CatalogPackage modelPackage; /** * Creates an instance of the switch. * <!-- begin-user-doc --> * <!-- end-user-doc --> * * @generated */ public CatalogSwitch() { if(modelPackage == null) { modelPackage = CatalogPackage.eINSTANCE; } } /** * Returns the result of interpreting the object as an instance of '<em>Catalog</em>'. * <!-- begin-user-doc --> * This implementation returns null; * returning a non-null result will terminate the switch. * <!-- end-user-doc --> * * @param object * the target of the switch. * @return the result of interpreting the object as an instance of '<em>Catalog</em>'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseCatalog(Catalog object) { return null; } /** * Returns the result of interpreting the object as an instance of '<em>Edge</em>'. * <!-- begin-user-doc --> * This implementation returns null; * returning a non-null result will terminate the switch. * <!-- end-user-doc --> * * @param object * the target of the switch. * @return the result of interpreting the object as an instance of '<em>Edge</em>'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseCatalogEdge(CatalogEdge object) { return null; } /** * Returns the result of interpreting the object as an instance of '<em>Metadata</em>'. * <!-- begin-user-doc --> * This implementation returns null; * returning a non-null result will terminate the switch. * <!-- end-user-doc --> * * @param object * the target of the switch. * @return the result of interpreting the object as an instance of '<em>Metadata</em>'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseCatalogMetadata(CatalogMetadata object) { return null; } /** * Returns the result of interpreting the object as an instance of '<em>Resource</em>'. * <!-- begin-user-doc --> * This implementation returns null; * returning a non-null result will terminate the switch. * <!-- end-user-doc --> * * @param object * the target of the switch. * @return the result of interpreting the object as an instance of '<em>Resource</em>'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseCatalogResource(CatalogResource object) { return null; } /** * Returns the result of interpreting the object as an instance of '<em>Resource Parameter</em>'. * <!-- begin-user-doc --> * This implementation returns null; * returning a non-null result will terminate the switch. * <!-- end-user-doc --> * * @param object * the target of the switch. * @return the result of interpreting the object as an instance of '<em>Resource Parameter</em>'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseCatalogResourceParameter(CatalogResourceParameter object) { return null; } /** * Returns the result of interpreting the object as an instance of '<em>Taggable</em>'. * <!-- begin-user-doc --> * This implementation returns null; * returning a non-null result will terminate the switch. * <!-- end-user-doc --> * * @param object * the target of the switch. * @return the result of interpreting the object as an instance of '<em>Taggable</em>'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) doSwitch(EObject) * @generated */ public T caseTaggable(Taggable object) { return null; } /** * Returns the result of interpreting the object as an instance of '<em>EObject</em>'. * <!-- begin-user-doc --> * This implementation returns null; * returning a non-null result will terminate the switch, but this is the last case anyway. * <!-- end-user-doc --> * * @param object * the target of the switch. * @return the result of interpreting the object as an instance of '<em>EObject</em>'. * @see #doSwitch(org.eclipse.emf.ecore.EObject) * @generated */ @Override public T defaultCase(EObject object) { return null; } /** * Calls <code>caseXXX</code> for each class of the model until one returns a non null result; it yields that result. * <!-- begin-user-doc --> * <!-- end-user-doc --> * * @return the first non-null result returned by a <code>caseXXX</code> call. * @generated */ @Override protected T doSwitch(int classifierID, EObject theEObject) { switch(classifierID) { case CatalogPackage.CATALOG: { Catalog catalog = (Catalog) theEObject; T result = caseCatalog(catalog); if(result == null) result = caseTaggable(catalog); if(result == null) result = defaultCase(theEObject); return result; } case CatalogPackage.CATALOG_RESOURCE: { CatalogResource catalogResource = (CatalogResource) theEObject; T result = caseCatalogResource(catalogResource); if(result == null) result = caseTaggable(catalogResource); if(result == null) result = defaultCase(theEObject); return result; } case CatalogPackage.CATALOG_METADATA: { CatalogMetadata catalogMetadata = (CatalogMetadata) theEObject; T result = caseCatalogMetadata(catalogMetadata); if(result == null) result = defaultCase(theEObject); return result; } case CatalogPackage.CATALOG_EDGE: { CatalogEdge catalogEdge = (CatalogEdge) theEObject; T result = caseCatalogEdge(catalogEdge); if(result == null) result = defaultCase(theEObject); return result; } case CatalogPackage.CATALOG_RESOURCE_PARAMETER: { CatalogResourceParameter catalogResourceParameter = (CatalogResourceParameter) theEObject; T result = caseCatalogResourceParameter(catalogResourceParameter); if(result == null) result = defaultCase(theEObject); return result; } case CatalogPackage.TAGGABLE: { Taggable taggable = (Taggable) theEObject; T result = caseTaggable(taggable); if(result == null) result = defaultCase(theEObject); return result; } default: return defaultCase(theEObject); } } /** * Checks whether this is a switch for the given package. * <!-- begin-user-doc --> * <!-- end-user-doc --> * * @parameter 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; } } // CatalogSwitch