/**
*/
package org.eclipse.viatra.solver.language.solverLanguage.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.viatra.solver.language.solverLanguage.SolverLanguagePackage;
import org.eclipse.viatra.solver.language.solverLanguage.TypeReference;
import org.eclipse.viatra.solver.language.solverLanguage.TypedArgument;
/**
*
* An implementation of the model object 'Typed Argument'.
*
*
* The following features are implemented:
*
*
* - {@link org.eclipse.viatra.solver.language.solverLanguage.impl.TypedArgumentImpl#getTypeReference Type Reference}
*
*
* @generated
*/
public abstract class TypedArgumentImpl extends ArgumentImpl implements TypedArgument {
/**
* The cached value of the '{@link #getTypeReference() Type Reference}' containment reference.
*
*
* @see #getTypeReference()
* @generated
* @ordered
*/
protected TypeReference typeReference;
/**
*
*
* @generated
*/
protected TypedArgumentImpl() {
super();
}
/**
*
*
* @generated
*/
@Override
protected EClass eStaticClass() {
return SolverLanguagePackage.Literals.TYPED_ARGUMENT;
}
/**
*
*
* @generated
*/
public TypeReference getTypeReference() {
return typeReference;
}
/**
*
*
* @generated
*/
public NotificationChain basicSetTypeReference(TypeReference newTypeReference, NotificationChain msgs) {
TypeReference oldTypeReference = typeReference;
typeReference = newTypeReference;
if (eNotificationRequired()) {
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET,
SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE, oldTypeReference, newTypeReference);
if (msgs == null)
msgs = notification;
else
msgs.add(notification);
}
return msgs;
}
/**
*
*
* @generated
*/
public void setTypeReference(TypeReference newTypeReference) {
if (newTypeReference != typeReference) {
NotificationChain msgs = null;
if (typeReference != null)
msgs = ((InternalEObject) typeReference).eInverseRemove(this,
EOPPOSITE_FEATURE_BASE - SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE, null, msgs);
if (newTypeReference != null)
msgs = ((InternalEObject) newTypeReference).eInverseAdd(this,
EOPPOSITE_FEATURE_BASE - SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE, null, msgs);
msgs = basicSetTypeReference(newTypeReference, msgs);
if (msgs != null)
msgs.dispatch();
} else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE,
newTypeReference, newTypeReference));
}
/**
*
*
* @generated
*/
@Override
public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) {
switch (featureID) {
case SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE:
return basicSetTypeReference(null, msgs);
}
return super.eInverseRemove(otherEnd, featureID, msgs);
}
/**
*
*
* @generated
*/
@Override
public Object eGet(int featureID, boolean resolve, boolean coreType) {
switch (featureID) {
case SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE:
return getTypeReference();
}
return super.eGet(featureID, resolve, coreType);
}
/**
*
*
* @generated
*/
@Override
public void eSet(int featureID, Object newValue) {
switch (featureID) {
case SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE:
setTypeReference((TypeReference) newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
*
*
* @generated
*/
@Override
public void eUnset(int featureID) {
switch (featureID) {
case SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE:
setTypeReference((TypeReference) null);
return;
}
super.eUnset(featureID);
}
/**
*
*
* @generated
*/
@Override
public boolean eIsSet(int featureID) {
switch (featureID) {
case SolverLanguagePackage.TYPED_ARGUMENT__TYPE_REFERENCE:
return typeReference != null;
}
return super.eIsSet(featureID);
}
} //TypedArgumentImpl