/*****************************************************************************
* 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