/************************************************************************** * ERA - Eclipse Requirements Analysis * ============================================== * Copyright (C) 2009-2013 by Georg Blaschke, Christoph P. Neumann * and Bernd Haberstumpf (http://era.origo.ethz.ch) ************************************************************************** * Licensed under the Eclipse Public License - v 1.0 (the "License"); * you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.eclipse.org/org/documents/epl-v10.html * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. ************************************************************************** */ package era.foss.erf.impl; import era.foss.erf.AttributeValueEnumeration; import era.foss.erf.EnumValue; import era.foss.erf.ErfPackage; import java.util.Collection; import org.eclipse.emf.common.util.EList; import org.eclipse.emf.ecore.EClass; import org.eclipse.emf.ecore.util.EObjectResolvingEList; /** * <!-- begin-user-doc --> * An implementation of the model object '<em><b>Attribute Value Enumeration</b></em>'. * <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link era.foss.erf.impl.AttributeValueEnumerationImpl#getValues <em>Values</em>}</li> * </ul> * </p> * * @generated */ public class AttributeValueEnumerationImpl extends AttributeValueImpl implements AttributeValueEnumeration { /** * The cached value of the '{@link #getValues() <em>Values</em>}' reference list. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getValues() * @generated * @ordered */ protected EList<EnumValue> values; /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ protected AttributeValueEnumerationImpl() { super(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return ErfPackage.Literals.ATTRIBUTE_VALUE_ENUMERATION; } /** * <!-- begin-user-doc --> * <!-- end-user-doc -->. * * @return the values * @generated */ public EList<EnumValue> getValues() { if( values == null ) { values = new EObjectResolvingEList<EnumValue>( EnumValue.class, this, ErfPackage.ATTRIBUTE_VALUE_ENUMERATION__VALUES ); } return values; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public Object eGet( int featureID, boolean resolve, boolean coreType ) { switch (featureID) { case ErfPackage.ATTRIBUTE_VALUE_ENUMERATION__VALUES: return getValues(); } return super.eGet( featureID, resolve, coreType ); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @SuppressWarnings("unchecked") @Override public void eSet( int featureID, Object newValue ) { switch (featureID) { case ErfPackage.ATTRIBUTE_VALUE_ENUMERATION__VALUES: getValues().clear(); getValues().addAll( (Collection<? extends EnumValue>)newValue ); return; } super.eSet( featureID, newValue ); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public void eUnset( int featureID ) { switch (featureID) { case ErfPackage.ATTRIBUTE_VALUE_ENUMERATION__VALUES: getValues().clear(); return; } super.eUnset( featureID ); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public boolean eIsSet( int featureID ) { switch (featureID) { case ErfPackage.ATTRIBUTE_VALUE_ENUMERATION__VALUES: return values != null && !values.isEmpty(); } return super.eIsSet( featureID ); } } //AttributeValueEnumerationImpl