/*******************************************************************************
* 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:
*
* - {@link org.eclipse.jpt.core.resource.orm.EntityListeners#getEntityListeners Entity Listeners}
*
*
*
* @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 extends EntityListener>)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())
};
}
}