/** */ package robot.FlotCtrl.impl; import org.eclipse.emf.common.notify.Notification; import org.eclipse.emf.common.notify.NotificationChain; 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 robot.FlotCtrl.BoolExp; import robot.FlotCtrl.FlotCtrlPackage; import robot.FlotCtrl.NegExp; /** * <!-- begin-user-doc --> * An implementation of the model object '<em><b>Neg Exp</b></em>'. * <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link robot.FlotCtrl.impl.NegExpImpl#getExp <em>Exp</em>}</li> * </ul> * </p> * * @generated */ public class NegExpImpl extends MinimalEObjectImpl.Container implements NegExp { /** * The cached value of the '{@link #getExp() <em>Exp</em>}' containment reference. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getExp() * @generated * @ordered */ protected BoolExp exp; /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ protected NegExpImpl() { super(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return FlotCtrlPackage.Literals.NEG_EXP; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public BoolExp getExp() { return exp; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public NotificationChain basicSetExp(BoolExp newExp, NotificationChain msgs) { BoolExp oldExp = exp; exp = newExp; if (eNotificationRequired()) { ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, FlotCtrlPackage.NEG_EXP__EXP, oldExp, newExp); if (msgs == null) msgs = notification; else msgs.add(notification); } return msgs; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setExp(BoolExp newExp) { if (newExp != exp) { NotificationChain msgs = null; if (exp != null) msgs = ((InternalEObject)exp).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - FlotCtrlPackage.NEG_EXP__EXP, null, msgs); if (newExp != null) msgs = ((InternalEObject)newExp).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - FlotCtrlPackage.NEG_EXP__EXP, null, msgs); msgs = basicSetExp(newExp, msgs); if (msgs != null) msgs.dispatch(); } else if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, FlotCtrlPackage.NEG_EXP__EXP, newExp, newExp)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case FlotCtrlPackage.NEG_EXP__EXP: return basicSetExp(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 FlotCtrlPackage.NEG_EXP__EXP: return getExp(); } return super.eGet(featureID, resolve, coreType); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public void eSet(int featureID, Object newValue) { switch (featureID) { case FlotCtrlPackage.NEG_EXP__EXP: setExp((BoolExp)newValue); return; } super.eSet(featureID, newValue); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case FlotCtrlPackage.NEG_EXP__EXP: setExp((BoolExp)null); return; } super.eUnset(featureID); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case FlotCtrlPackage.NEG_EXP__EXP: return exp != null; } return super.eIsSet(featureID); } } //NegExpImpl