/** * <copyright> * </copyright> * * $Id$ */ package net.sf.orcc.df.impl; import java.util.Collection; import net.sf.orcc.df.DfPackage; import net.sf.orcc.df.Tag; import org.eclipse.emf.common.util.EList; import org.eclipse.emf.ecore.EClass; import org.eclipse.emf.ecore.impl.EObjectImpl; import org.eclipse.emf.ecore.util.EDataTypeUniqueEList; /** * <!-- begin-user-doc --> An implementation of the model object ' * <em><b>Tag</b></em>'. <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link net.sf.orcc.df.impl.TagImpl#getIdentifiers <em>Identifiers</em>}</li> * </ul> * </p> * * @generated */ public class TagImpl extends EObjectImpl implements Tag { /** * The cached value of the '{@link #getIdentifiers() <em>Identifiers</em>}' attribute list. * <!-- begin-user-doc --> <!-- end-user-doc --> * @see #getIdentifiers() * @generated * @ordered */ protected EList<String> identifiers; /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ protected TagImpl() { super(); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return DfPackage.Literals.TAG; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public EList<String> getIdentifiers() { if (identifiers == null) { identifiers = new EDataTypeUniqueEList<String>(String.class, this, DfPackage.TAG__IDENTIFIERS); } return identifiers; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override public Object eGet(int featureID, boolean resolve, boolean coreType) { switch (featureID) { case DfPackage.TAG__IDENTIFIERS: return getIdentifiers(); } 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 DfPackage.TAG__IDENTIFIERS: getIdentifiers().clear(); getIdentifiers().addAll((Collection<? extends String>) newValue); return; } super.eSet(featureID, newValue); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case DfPackage.TAG__IDENTIFIERS: getIdentifiers().clear(); return; } super.eUnset(featureID); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case DfPackage.TAG__IDENTIFIERS: return identifiers != null && !identifiers.isEmpty(); } return super.eIsSet(featureID); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public String toString() { if (eIsProxy()) return super.toString(); StringBuffer result = new StringBuffer(super.toString()); result.append(" (identifiers: "); result.append(identifiers); result.append(')'); return result.toString(); } /** * Adds an identifier to this tag. * * @param identifier * an identifier */ public void add(String identifier) { getIdentifiers().add(identifier); } @Override public boolean equals(Object obj) { if (obj instanceof Tag) { return getIdentifiers().equals(((Tag) obj).getIdentifiers()); } else { return false; } } /** * Returns the identifier at the given index. * * @param index * index of the identifier to return * @return the identifier at the given index */ public String get(int index) { return getIdentifiers().get(index); } @Override public int hashCode() { return getIdentifiers().hashCode(); } /** * Returns true if this tag is empty. * * @return true if this tag is empty */ public boolean isEmpty() { return getIdentifiers().isEmpty(); } /** * Returns the number of identifiers in this tag. * * @return the number of identifiers in this tag */ public int size() { return getIdentifiers().size(); } } // TagImpl