/******************************************************************************* * Copyright (c) 2008, 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.eclipselink.core.resource.orm; import java.util.Collection; import org.eclipse.emf.common.notify.Notification; 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.impl.ENotificationImpl; 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.orm.AbstractXmlAttributeMapping; import org.eclipse.jpt.eclipselink.core.EclipseLinkMappingKeys; import org.eclipse.wst.common.internal.emf.resource.Translator; /** * * A representation of the model object 'Xml Basic Map Impl'. * * 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. * * * * * * @see org.eclipse.jpt.eclipselink.core.resource.orm.EclipseLinkOrmPackage#getXmlBasicMap() * @model kind="class" * @generated */ public class XmlBasicMap extends AbstractXmlAttributeMapping implements XmlAttributeMapping { /** * The cached value of the '{@link #getAccessMethods() Access Methods}' containment reference. * * * @see #getAccessMethods() * @generated * @ordered */ protected XmlAccessMethods accessMethods; /** * The cached value of the '{@link #getProperties() Properties}' containment reference list. * * * @see #getProperties() * @generated * @ordered */ protected EList properties; /** * * * @generated */ protected XmlBasicMap() { super(); } /** * * * @generated */ @Override protected EClass eStaticClass() { return EclipseLinkOrmPackage.Literals.XML_BASIC_MAP; } /** * Returns the value of the 'Access Methods' containment reference. * *

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

* * @return the value of the 'Access Methods' containment reference. * @see #setAccessMethods(XmlAccessMethods) * @see org.eclipse.jpt.eclipselink.core.resource.orm.EclipseLinkOrmPackage#getXmlAccessMethodsHolder_AccessMethods() * @model containment="true" * @generated */ public XmlAccessMethods getAccessMethods() { return accessMethods; } /** * * * @generated */ public NotificationChain basicSetAccessMethods(XmlAccessMethods newAccessMethods, NotificationChain msgs) { XmlAccessMethods oldAccessMethods = accessMethods; accessMethods = newAccessMethods; if (eNotificationRequired()) { ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS, oldAccessMethods, newAccessMethods); if (msgs == null) msgs = notification; else msgs.add(notification); } return msgs; } /** * Sets the value of the '{@link org.eclipse.jpt.eclipselink.core.resource.orm.XmlBasicMap#getAccessMethods Access Methods}' containment reference. * * * @param value the new value of the 'Access Methods' containment reference. * @see #getAccessMethods() * @generated */ public void setAccessMethods(XmlAccessMethods newAccessMethods) { if (newAccessMethods != accessMethods) { NotificationChain msgs = null; if (accessMethods != null) msgs = ((InternalEObject)accessMethods).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS, null, msgs); if (newAccessMethods != null) msgs = ((InternalEObject)newAccessMethods).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS, null, msgs); msgs = basicSetAccessMethods(newAccessMethods, msgs); if (msgs != null) msgs.dispatch(); } else if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS, newAccessMethods, newAccessMethods)); } /** * Returns the value of the 'Properties' containment reference list. * The list contents are of type {@link org.eclipse.jpt.eclipselink.core.resource.orm.XmlProperty}. * *

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

* * @return the value of the 'Properties' containment reference list. * @see org.eclipse.jpt.eclipselink.core.resource.orm.EclipseLinkOrmPackage#getXmlPropertyContainer_Properties() * @model containment="true" * @generated */ public EList getProperties() { if (properties == null) { properties = new EObjectContainmentEList(XmlProperty.class, this, EclipseLinkOrmPackage.XML_BASIC_MAP__PROPERTIES); } return properties; } /** * * * @generated */ @Override public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS: return basicSetAccessMethods(null, msgs); case EclipseLinkOrmPackage.XML_BASIC_MAP__PROPERTIES: return ((InternalEList)getProperties()).basicRemove(otherEnd, msgs); } return super.eInverseRemove(otherEnd, featureID, msgs); } /** * * * @generated */ @Override public Object eGet(int featureID, boolean resolve, boolean coreType) { switch (featureID) { case EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS: return getAccessMethods(); case EclipseLinkOrmPackage.XML_BASIC_MAP__PROPERTIES: return getProperties(); } return super.eGet(featureID, resolve, coreType); } /** * * * @generated */ @SuppressWarnings("unchecked") @Override public void eSet(int featureID, Object newValue) { switch (featureID) { case EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS: setAccessMethods((XmlAccessMethods)newValue); return; case EclipseLinkOrmPackage.XML_BASIC_MAP__PROPERTIES: getProperties().clear(); getProperties().addAll((Collection)newValue); return; } super.eSet(featureID, newValue); } /** * * * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS: setAccessMethods((XmlAccessMethods)null); return; case EclipseLinkOrmPackage.XML_BASIC_MAP__PROPERTIES: getProperties().clear(); return; } super.eUnset(featureID); } /** * * * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS: return accessMethods != null; case EclipseLinkOrmPackage.XML_BASIC_MAP__PROPERTIES: return properties != null && !properties.isEmpty(); } return super.eIsSet(featureID); } /** * * * @generated */ @Override public int eBaseStructuralFeatureID(int derivedFeatureID, Class baseClass) { if (baseClass == XmlAccessMethodsHolder.class) { switch (derivedFeatureID) { case EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS: return EclipseLinkOrmPackage.XML_ACCESS_METHODS_HOLDER__ACCESS_METHODS; default: return -1; } } if (baseClass == XmlPropertyContainer.class) { switch (derivedFeatureID) { case EclipseLinkOrmPackage.XML_BASIC_MAP__PROPERTIES: return EclipseLinkOrmPackage.XML_PROPERTY_CONTAINER__PROPERTIES; default: return -1; } } if (baseClass == XmlAttributeMapping.class) { switch (derivedFeatureID) { default: return -1; } } return super.eBaseStructuralFeatureID(derivedFeatureID, baseClass); } /** * * * @generated */ @Override public int eDerivedStructuralFeatureID(int baseFeatureID, Class baseClass) { if (baseClass == XmlAccessMethodsHolder.class) { switch (baseFeatureID) { case EclipseLinkOrmPackage.XML_ACCESS_METHODS_HOLDER__ACCESS_METHODS: return EclipseLinkOrmPackage.XML_BASIC_MAP__ACCESS_METHODS; default: return -1; } } if (baseClass == XmlPropertyContainer.class) { switch (baseFeatureID) { case EclipseLinkOrmPackage.XML_PROPERTY_CONTAINER__PROPERTIES: return EclipseLinkOrmPackage.XML_BASIC_MAP__PROPERTIES; default: return -1; } } if (baseClass == XmlAttributeMapping.class) { switch (baseFeatureID) { default: return -1; } } return super.eDerivedStructuralFeatureID(baseFeatureID, baseClass); } public String getMappingKey() { return EclipseLinkMappingKeys.BASIC_MAP_ATTRIBUTE_MAPPING_KEY; } // ********** translators ********** public static Translator buildTranslator(String elementName, EStructuralFeature structuralFeature) { return new SimpleTranslator(elementName, structuralFeature, buildTranslatorChildren()); } private static Translator[] buildTranslatorChildren() { return new Translator[] { buildNameTranslator(), buildAccessTranslator() }; } }