/***************************************************************************** * Copyright (c) 2011 CEA LIST. * * * 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: * CEA LIST - Initial API and implementation * *****************************************************************************/ package org.eclipse.papyrus.uml.alf.alf.impl; 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.InternalEObject; import org.eclipse.emf.ecore.impl.ENotificationImpl; import org.eclipse.emf.ecore.impl.MinimalEObjectImpl; import org.eclipse.emf.ecore.util.EObjectContainmentEList; import org.eclipse.emf.ecore.util.InternalEList; import org.eclipse.papyrus.uml.alf.alf.AlfPackage; import org.eclipse.papyrus.uml.alf.alf.AssignmentCompletion; import org.eclipse.papyrus.uml.alf.alf.Block; import org.eclipse.papyrus.uml.alf.alf.Expression; import org.eclipse.papyrus.uml.alf.alf.Statement; import org.eclipse.papyrus.uml.alf.alf.Test; /** * <!-- begin-user-doc --> * An implementation of the model object '<em><b>Test</b></em>'. * <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link org.eclipse.papyrus.uml.alf.alf.impl.TestImpl#getExpression <em>Expression</em>}</li> * <li>{@link org.eclipse.papyrus.uml.alf.alf.impl.TestImpl#getAssignExpression <em>Assign Expression</em>}</li> * <li>{@link org.eclipse.papyrus.uml.alf.alf.impl.TestImpl#getStatements <em>Statements</em>}</li> * <li>{@link org.eclipse.papyrus.uml.alf.alf.impl.TestImpl#getBlock <em>Block</em>}</li> * </ul> * </p> * * @generated */ public class TestImpl extends MinimalEObjectImpl.Container implements Test { /** * The cached value of the '{@link #getExpression() <em>Expression</em>}' containment reference list. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getExpression() * @generated * @ordered */ protected EList<Expression> expression; /** * The cached value of the '{@link #getAssignExpression() <em>Assign Expression</em>}' containment reference list. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getAssignExpression() * @generated * @ordered */ protected EList<AssignmentCompletion> assignExpression; /** * The cached value of the '{@link #getStatements() <em>Statements</em>}' containment reference list. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getStatements() * @generated * @ordered */ protected EList<Statement> statements; /** * The cached value of the '{@link #getBlock() <em>Block</em>}' containment reference. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getBlock() * @generated * @ordered */ protected Block block; /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ protected TestImpl() { super(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return AlfPackage.Literals.TEST; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public EList<Expression> getExpression() { if (expression == null) { expression = new EObjectContainmentEList<Expression>(Expression.class, this, AlfPackage.TEST__EXPRESSION); } return expression; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public EList<AssignmentCompletion> getAssignExpression() { if (assignExpression == null) { assignExpression = new EObjectContainmentEList<AssignmentCompletion>(AssignmentCompletion.class, this, AlfPackage.TEST__ASSIGN_EXPRESSION); } return assignExpression; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public EList<Statement> getStatements() { if (statements == null) { statements = new EObjectContainmentEList<Statement>(Statement.class, this, AlfPackage.TEST__STATEMENTS); } return statements; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public Block getBlock() { return block; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public NotificationChain basicSetBlock(Block newBlock, NotificationChain msgs) { Block oldBlock = block; block = newBlock; if (eNotificationRequired()) { ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, AlfPackage.TEST__BLOCK, oldBlock, newBlock); if (msgs == null) msgs = notification; else msgs.add(notification); } return msgs; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setBlock(Block newBlock) { if (newBlock != block) { NotificationChain msgs = null; if (block != null) msgs = ((InternalEObject)block).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - AlfPackage.TEST__BLOCK, null, msgs); if (newBlock != null) msgs = ((InternalEObject)newBlock).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - AlfPackage.TEST__BLOCK, null, msgs); msgs = basicSetBlock(newBlock, msgs); if (msgs != null) msgs.dispatch(); } else if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, AlfPackage.TEST__BLOCK, newBlock, newBlock)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case AlfPackage.TEST__EXPRESSION: return ((InternalEList<?>)getExpression()).basicRemove(otherEnd, msgs); case AlfPackage.TEST__ASSIGN_EXPRESSION: return ((InternalEList<?>)getAssignExpression()).basicRemove(otherEnd, msgs); case AlfPackage.TEST__STATEMENTS: return ((InternalEList<?>)getStatements()).basicRemove(otherEnd, msgs); case AlfPackage.TEST__BLOCK: return basicSetBlock(null, msgs); } return super.eInverseRemove(otherEnd, featureID, msgs); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public Object eGet(int featureID, boolean resolve, boolean coreType) { switch (featureID) { case AlfPackage.TEST__EXPRESSION: return getExpression(); case AlfPackage.TEST__ASSIGN_EXPRESSION: return getAssignExpression(); case AlfPackage.TEST__STATEMENTS: return getStatements(); case AlfPackage.TEST__BLOCK: return getBlock(); } 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 AlfPackage.TEST__EXPRESSION: getExpression().clear(); getExpression().addAll((Collection<? extends Expression>)newValue); return; case AlfPackage.TEST__ASSIGN_EXPRESSION: getAssignExpression().clear(); getAssignExpression().addAll((Collection<? extends AssignmentCompletion>)newValue); return; case AlfPackage.TEST__STATEMENTS: getStatements().clear(); getStatements().addAll((Collection<? extends Statement>)newValue); return; case AlfPackage.TEST__BLOCK: setBlock((Block)newValue); return; } super.eSet(featureID, newValue); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case AlfPackage.TEST__EXPRESSION: getExpression().clear(); return; case AlfPackage.TEST__ASSIGN_EXPRESSION: getAssignExpression().clear(); return; case AlfPackage.TEST__STATEMENTS: getStatements().clear(); return; case AlfPackage.TEST__BLOCK: setBlock((Block)null); return; } super.eUnset(featureID); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case AlfPackage.TEST__EXPRESSION: return expression != null && !expression.isEmpty(); case AlfPackage.TEST__ASSIGN_EXPRESSION: return assignExpression != null && !assignExpression.isEmpty(); case AlfPackage.TEST__STATEMENTS: return statements != null && !statements.isEmpty(); case AlfPackage.TEST__BLOCK: return block != null; } return super.eIsSet(featureID); } } //TestImpl