/******************************************************************************* * Copyright (c) 2007, 2009 Oracle. 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: * Oracle - initial API and implementation ******************************************************************************/ package org.eclipse.jpt.core.resource.orm; import java.util.Collection; import org.eclipse.emf.common.notify.NotificationChain; import org.eclipse.emf.common.util.EList; import org.eclipse.emf.ecore.EClass; import org.eclipse.emf.ecore.EStructuralFeature; import org.eclipse.emf.ecore.InternalEObject; import org.eclipse.emf.ecore.util.EObjectContainmentEList; import org.eclipse.emf.ecore.util.InternalEList; import org.eclipse.jpt.core.internal.utility.translators.SimpleTranslator; import org.eclipse.jpt.core.resource.xml.AbstractJpaEObject; import org.eclipse.jpt.core.resource.xml.JpaEObject; import org.eclipse.wst.common.internal.emf.resource.Translator; /** * * A representation of the model object 'Entity Listeners'. * * Provisional API: This interface is part of an interim API that is still * under development and expected to change significantly before reaching * stability. It is available at this early stage to solicit feedback from * pioneering adopters on the understanding that any code that uses this API * will almost certainly be broken (repeatedly) as the API evolves. * * *

* The following features are supported: *

*

* * @see org.eclipse.jpt.core.resource.orm.OrmPackage#getEntityListeners() * @model kind="class" * @extends JpaEObject * @generated */ public class EntityListeners extends AbstractJpaEObject implements JpaEObject { /** * The cached value of the '{@link #getEntityListeners() Entity Listeners}' containment reference list. * * * @see #getEntityListeners() * @generated * @ordered */ protected EList entityListeners; /** * * * @generated */ protected EntityListeners() { super(); } /** * * * @generated */ @Override protected EClass eStaticClass() { return OrmPackage.Literals.ENTITY_LISTENERS; } /** * Returns the value of the 'Entity Listeners' containment reference list. * The list contents are of type {@link org.eclipse.jpt.core.resource.orm.EntityListener}. * *

* If the meaning of the 'Entity Listeners' containment reference list isn't clear, * there really should be more of a description here... *

* * @return the value of the 'Entity Listeners' containment reference list. * @see org.eclipse.jpt.core.resource.orm.OrmPackage#getEntityListeners_EntityListeners() * @model containment="true" * @generated */ public EList getEntityListeners() { if (entityListeners == null) { entityListeners = new EObjectContainmentEList(EntityListener.class, this, OrmPackage.ENTITY_LISTENERS__ENTITY_LISTENERS); } return entityListeners; } /** * * * @generated */ @Override public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case OrmPackage.ENTITY_LISTENERS__ENTITY_LISTENERS: return ((InternalEList)getEntityListeners()).basicRemove(otherEnd, msgs); } return super.eInverseRemove(otherEnd, featureID, msgs); } /** * * * @generated */ @Override public Object eGet(int featureID, boolean resolve, boolean coreType) { switch (featureID) { case OrmPackage.ENTITY_LISTENERS__ENTITY_LISTENERS: return getEntityListeners(); } return super.eGet(featureID, resolve, coreType); } /** * * * @generated */ @SuppressWarnings("unchecked") @Override public void eSet(int featureID, Object newValue) { switch (featureID) { case OrmPackage.ENTITY_LISTENERS__ENTITY_LISTENERS: getEntityListeners().clear(); getEntityListeners().addAll((Collection)newValue); return; } super.eSet(featureID, newValue); } /** * * * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case OrmPackage.ENTITY_LISTENERS__ENTITY_LISTENERS: getEntityListeners().clear(); return; } super.eUnset(featureID); } /** * * * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case OrmPackage.ENTITY_LISTENERS__ENTITY_LISTENERS: return entityListeners != null && !entityListeners.isEmpty(); } return super.eIsSet(featureID); } // ********** translators ********** public static Translator buildTranslator(String elementName, EStructuralFeature structuralFeature) { return new SimpleTranslator(elementName, structuralFeature, buildTranslatorChildren()); } private static Translator[] buildTranslatorChildren() { return new Translator[] { EntityListener.buildTranslator(JPA.ENTITY_LISTENER, OrmPackage.eINSTANCE.getEntityListeners_EntityListeners()) }; } }