/**
*/
package emfviews.dsl.sqlview.impl;
import emfviews.dsl.sqlview.Condition;
import emfviews.dsl.sqlview.Expression;
import emfviews.dsl.sqlview.From;
import emfviews.dsl.sqlview.Select;
import emfviews.dsl.sqlview.SqlviewPackage;
import java.util.Collection;
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.MinimalEObjectImpl;
import org.eclipse.emf.ecore.util.EObjectContainmentEList;
import org.eclipse.emf.ecore.util.InternalEList;
/**
* <!-- begin-user-doc -->
* An implementation of the model object '<em><b>Expression</b></em>'.
* <!-- end-user-doc -->
* <p>
* The following features are implemented:
* <ul>
* <li>{@link emfviews.dsl.sqlview.impl.ExpressionImpl#getSelect <em>Select</em>}</li>
* <li>{@link emfviews.dsl.sqlview.impl.ExpressionImpl#getFrom <em>From</em>}</li>
* <li>{@link emfviews.dsl.sqlview.impl.ExpressionImpl#getCondition <em>Condition</em>}</li>
* </ul>
* </p>
*
* @generated
*/
public class ExpressionImpl extends MinimalEObjectImpl.Container implements Expression
{
/**
* The cached value of the '{@link #getSelect() <em>Select</em>}' containment reference list.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getSelect()
* @generated
* @ordered
*/
protected EList<Select> select;
/**
* The cached value of the '{@link #getFrom() <em>From</em>}' containment reference list.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getFrom()
* @generated
* @ordered
*/
protected EList<From> from;
/**
* The cached value of the '{@link #getCondition() <em>Condition</em>}' containment reference list.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getCondition()
* @generated
* @ordered
*/
protected EList<Condition> condition;
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected ExpressionImpl()
{
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass()
{
return SqlviewPackage.Literals.EXPRESSION;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public EList<Select> getSelect()
{
if (select == null)
{
select = new EObjectContainmentEList<Select>(Select.class, this, SqlviewPackage.EXPRESSION__SELECT);
}
return select;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public EList<From> getFrom()
{
if (from == null)
{
from = new EObjectContainmentEList<From>(From.class, this, SqlviewPackage.EXPRESSION__FROM);
}
return from;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public EList<Condition> getCondition()
{
if (condition == null)
{
condition = new EObjectContainmentEList<Condition>(Condition.class, this, SqlviewPackage.EXPRESSION__CONDITION);
}
return condition;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs)
{
switch (featureID)
{
case SqlviewPackage.EXPRESSION__SELECT:
return ((InternalEList<?>)getSelect()).basicRemove(otherEnd, msgs);
case SqlviewPackage.EXPRESSION__FROM:
return ((InternalEList<?>)getFrom()).basicRemove(otherEnd, msgs);
case SqlviewPackage.EXPRESSION__CONDITION:
return ((InternalEList<?>)getCondition()).basicRemove(otherEnd, 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 SqlviewPackage.EXPRESSION__SELECT:
return getSelect();
case SqlviewPackage.EXPRESSION__FROM:
return getFrom();
case SqlviewPackage.EXPRESSION__CONDITION:
return getCondition();
}
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 SqlviewPackage.EXPRESSION__SELECT:
getSelect().clear();
getSelect().addAll((Collection<? extends Select>)newValue);
return;
case SqlviewPackage.EXPRESSION__FROM:
getFrom().clear();
getFrom().addAll((Collection<? extends From>)newValue);
return;
case SqlviewPackage.EXPRESSION__CONDITION:
getCondition().clear();
getCondition().addAll((Collection<? extends Condition>)newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(int featureID)
{
switch (featureID)
{
case SqlviewPackage.EXPRESSION__SELECT:
getSelect().clear();
return;
case SqlviewPackage.EXPRESSION__FROM:
getFrom().clear();
return;
case SqlviewPackage.EXPRESSION__CONDITION:
getCondition().clear();
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(int featureID)
{
switch (featureID)
{
case SqlviewPackage.EXPRESSION__SELECT:
return select != null && !select.isEmpty();
case SqlviewPackage.EXPRESSION__FROM:
return from != null && !from.isEmpty();
case SqlviewPackage.EXPRESSION__CONDITION:
return condition != null && !condition.isEmpty();
}
return super.eIsSet(featureID);
}
} //ExpressionImpl