/**
* <copyright>
* </copyright>
*
*/
package at.bestsolution.efxclipse.tooling.svgpath.svgPath.impl;
import at.bestsolution.efxclipse.tooling.svgpath.svgPath.SvgPathPackage;
import at.bestsolution.efxclipse.tooling.svgpath.svgPath.digit_sequence;
import at.bestsolution.efxclipse.tooling.svgpath.svgPath.exponent;
import at.bestsolution.efxclipse.tooling.svgpath.svgPath.nonnegative_number;
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;
/**
* <!-- begin-user-doc -->
* An implementation of the model object '<em><b>nonnegative number</b></em>'.
* <!-- end-user-doc -->
* <p>
* The following features are implemented:
* <ul>
* <li>{@link at.bestsolution.efxclipse.tooling.svgpath.svgPath.impl.nonnegative_numberImpl#getIntseq <em>Intseq</em>}</li>
* <li>{@link at.bestsolution.efxclipse.tooling.svgpath.svgPath.impl.nonnegative_numberImpl#getFloatseq <em>Floatseq</em>}</li>
* <li>{@link at.bestsolution.efxclipse.tooling.svgpath.svgPath.impl.nonnegative_numberImpl#getExponent <em>Exponent</em>}</li>
* </ul>
* </p>
*
* @generated
*/
public class nonnegative_numberImpl extends MinimalEObjectImpl.Container implements nonnegative_number
{
/**
* The cached value of the '{@link #getIntseq() <em>Intseq</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getIntseq()
* @generated
* @ordered
*/
protected digit_sequence intseq;
/**
* The cached value of the '{@link #getFloatseq() <em>Floatseq</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getFloatseq()
* @generated
* @ordered
*/
protected digit_sequence floatseq;
/**
* The cached value of the '{@link #getExponent() <em>Exponent</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getExponent()
* @generated
* @ordered
*/
protected exponent exponent;
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected nonnegative_numberImpl()
{
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass()
{
return SvgPathPackage.Literals.NONNEGATIVE_NUMBER;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public digit_sequence getIntseq()
{
return intseq;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetIntseq(digit_sequence newIntseq, NotificationChain msgs)
{
digit_sequence oldIntseq = intseq;
intseq = newIntseq;
if (eNotificationRequired())
{
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ, oldIntseq, newIntseq);
if (msgs == null) msgs = notification; else msgs.add(notification);
}
return msgs;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setIntseq(digit_sequence newIntseq)
{
if (newIntseq != intseq)
{
NotificationChain msgs = null;
if (intseq != null)
msgs = ((InternalEObject)intseq).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ, null, msgs);
if (newIntseq != null)
msgs = ((InternalEObject)newIntseq).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ, null, msgs);
msgs = basicSetIntseq(newIntseq, msgs);
if (msgs != null) msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ, newIntseq, newIntseq));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public digit_sequence getFloatseq()
{
return floatseq;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetFloatseq(digit_sequence newFloatseq, NotificationChain msgs)
{
digit_sequence oldFloatseq = floatseq;
floatseq = newFloatseq;
if (eNotificationRequired())
{
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ, oldFloatseq, newFloatseq);
if (msgs == null) msgs = notification; else msgs.add(notification);
}
return msgs;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setFloatseq(digit_sequence newFloatseq)
{
if (newFloatseq != floatseq)
{
NotificationChain msgs = null;
if (floatseq != null)
msgs = ((InternalEObject)floatseq).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ, null, msgs);
if (newFloatseq != null)
msgs = ((InternalEObject)newFloatseq).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ, null, msgs);
msgs = basicSetFloatseq(newFloatseq, msgs);
if (msgs != null) msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ, newFloatseq, newFloatseq));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public exponent getExponent()
{
return exponent;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetExponent(exponent newExponent, NotificationChain msgs)
{
exponent oldExponent = exponent;
exponent = newExponent;
if (eNotificationRequired())
{
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT, oldExponent, newExponent);
if (msgs == null) msgs = notification; else msgs.add(notification);
}
return msgs;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setExponent(exponent newExponent)
{
if (newExponent != exponent)
{
NotificationChain msgs = null;
if (exponent != null)
msgs = ((InternalEObject)exponent).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT, null, msgs);
if (newExponent != null)
msgs = ((InternalEObject)newExponent).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT, null, msgs);
msgs = basicSetExponent(newExponent, msgs);
if (msgs != null) msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT, newExponent, newExponent));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs)
{
switch (featureID)
{
case SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ:
return basicSetIntseq(null, msgs);
case SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ:
return basicSetFloatseq(null, msgs);
case SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT:
return basicSetExponent(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 SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ:
return getIntseq();
case SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ:
return getFloatseq();
case SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT:
return getExponent();
}
return super.eGet(featureID, resolve, coreType);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eSet(int featureID, Object newValue)
{
switch (featureID)
{
case SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ:
setIntseq((digit_sequence)newValue);
return;
case SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ:
setFloatseq((digit_sequence)newValue);
return;
case SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT:
setExponent((exponent)newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(int featureID)
{
switch (featureID)
{
case SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ:
setIntseq((digit_sequence)null);
return;
case SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ:
setFloatseq((digit_sequence)null);
return;
case SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT:
setExponent((exponent)null);
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(int featureID)
{
switch (featureID)
{
case SvgPathPackage.NONNEGATIVE_NUMBER__INTSEQ:
return intseq != null;
case SvgPathPackage.NONNEGATIVE_NUMBER__FLOATSEQ:
return floatseq != null;
case SvgPathPackage.NONNEGATIVE_NUMBER__EXPONENT:
return exponent != null;
}
return super.eIsSet(featureID);
}
} //nonnegative_numberImpl