/** */ package com.robotoworks.mechanoid.db.sqliteModel.impl; import com.robotoworks.mechanoid.db.sqliteModel.Expression; import com.robotoworks.mechanoid.db.sqliteModel.OrderingTermList; import com.robotoworks.mechanoid.db.sqliteModel.SelectCoreExpression; import com.robotoworks.mechanoid.db.sqliteModel.SelectStatement; import com.robotoworks.mechanoid.db.sqliteModel.SqliteModelPackage; 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; /** * <!-- begin-user-doc --> * An implementation of the model object '<em><b>Select Statement</b></em>'. * <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link com.robotoworks.mechanoid.db.sqliteModel.impl.SelectStatementImpl#getCore <em>Core</em>}</li> * <li>{@link com.robotoworks.mechanoid.db.sqliteModel.impl.SelectStatementImpl#getOrderby <em>Orderby</em>}</li> * <li>{@link com.robotoworks.mechanoid.db.sqliteModel.impl.SelectStatementImpl#getLimit <em>Limit</em>}</li> * <li>{@link com.robotoworks.mechanoid.db.sqliteModel.impl.SelectStatementImpl#getLimitOffset <em>Limit Offset</em>}</li> * </ul> * </p> * * @generated */ public class SelectStatementImpl extends DMLStatementImpl implements SelectStatement { /** * The cached value of the '{@link #getCore() <em>Core</em>}' containment reference. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getCore() * @generated * @ordered */ protected SelectCoreExpression core; /** * The cached value of the '{@link #getOrderby() <em>Orderby</em>}' containment reference. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getOrderby() * @generated * @ordered */ protected OrderingTermList orderby; /** * The cached value of the '{@link #getLimit() <em>Limit</em>}' containment reference. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getLimit() * @generated * @ordered */ protected Expression limit; /** * The cached value of the '{@link #getLimitOffset() <em>Limit Offset</em>}' containment reference. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getLimitOffset() * @generated * @ordered */ protected Expression limitOffset; /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ protected SelectStatementImpl() { super(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return SqliteModelPackage.Literals.SELECT_STATEMENT; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public SelectCoreExpression getCore() { return core; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public NotificationChain basicSetCore(SelectCoreExpression newCore, NotificationChain msgs) { SelectCoreExpression oldCore = core; core = newCore; if (eNotificationRequired()) { ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, SqliteModelPackage.SELECT_STATEMENT__CORE, oldCore, newCore); if (msgs == null) msgs = notification; else msgs.add(notification); } return msgs; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setCore(SelectCoreExpression newCore) { if (newCore != core) { NotificationChain msgs = null; if (core != null) msgs = ((InternalEObject)core).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - SqliteModelPackage.SELECT_STATEMENT__CORE, null, msgs); if (newCore != null) msgs = ((InternalEObject)newCore).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - SqliteModelPackage.SELECT_STATEMENT__CORE, null, msgs); msgs = basicSetCore(newCore, msgs); if (msgs != null) msgs.dispatch(); } else if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, SqliteModelPackage.SELECT_STATEMENT__CORE, newCore, newCore)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public OrderingTermList getOrderby() { return orderby; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public NotificationChain basicSetOrderby(OrderingTermList newOrderby, NotificationChain msgs) { OrderingTermList oldOrderby = orderby; orderby = newOrderby; if (eNotificationRequired()) { ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, SqliteModelPackage.SELECT_STATEMENT__ORDERBY, oldOrderby, newOrderby); if (msgs == null) msgs = notification; else msgs.add(notification); } return msgs; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setOrderby(OrderingTermList newOrderby) { if (newOrderby != orderby) { NotificationChain msgs = null; if (orderby != null) msgs = ((InternalEObject)orderby).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - SqliteModelPackage.SELECT_STATEMENT__ORDERBY, null, msgs); if (newOrderby != null) msgs = ((InternalEObject)newOrderby).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - SqliteModelPackage.SELECT_STATEMENT__ORDERBY, null, msgs); msgs = basicSetOrderby(newOrderby, msgs); if (msgs != null) msgs.dispatch(); } else if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, SqliteModelPackage.SELECT_STATEMENT__ORDERBY, newOrderby, newOrderby)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public Expression getLimit() { return limit; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public NotificationChain basicSetLimit(Expression newLimit, NotificationChain msgs) { Expression oldLimit = limit; limit = newLimit; if (eNotificationRequired()) { ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, SqliteModelPackage.SELECT_STATEMENT__LIMIT, oldLimit, newLimit); if (msgs == null) msgs = notification; else msgs.add(notification); } return msgs; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setLimit(Expression newLimit) { if (newLimit != limit) { NotificationChain msgs = null; if (limit != null) msgs = ((InternalEObject)limit).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - SqliteModelPackage.SELECT_STATEMENT__LIMIT, null, msgs); if (newLimit != null) msgs = ((InternalEObject)newLimit).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - SqliteModelPackage.SELECT_STATEMENT__LIMIT, null, msgs); msgs = basicSetLimit(newLimit, msgs); if (msgs != null) msgs.dispatch(); } else if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, SqliteModelPackage.SELECT_STATEMENT__LIMIT, newLimit, newLimit)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public Expression getLimitOffset() { return limitOffset; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public NotificationChain basicSetLimitOffset(Expression newLimitOffset, NotificationChain msgs) { Expression oldLimitOffset = limitOffset; limitOffset = newLimitOffset; if (eNotificationRequired()) { ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET, oldLimitOffset, newLimitOffset); if (msgs == null) msgs = notification; else msgs.add(notification); } return msgs; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setLimitOffset(Expression newLimitOffset) { if (newLimitOffset != limitOffset) { NotificationChain msgs = null; if (limitOffset != null) msgs = ((InternalEObject)limitOffset).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET, null, msgs); if (newLimitOffset != null) msgs = ((InternalEObject)newLimitOffset).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET, null, msgs); msgs = basicSetLimitOffset(newLimitOffset, msgs); if (msgs != null) msgs.dispatch(); } else if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET, newLimitOffset, newLimitOffset)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case SqliteModelPackage.SELECT_STATEMENT__CORE: return basicSetCore(null, msgs); case SqliteModelPackage.SELECT_STATEMENT__ORDERBY: return basicSetOrderby(null, msgs); case SqliteModelPackage.SELECT_STATEMENT__LIMIT: return basicSetLimit(null, msgs); case SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET: return basicSetLimitOffset(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 SqliteModelPackage.SELECT_STATEMENT__CORE: return getCore(); case SqliteModelPackage.SELECT_STATEMENT__ORDERBY: return getOrderby(); case SqliteModelPackage.SELECT_STATEMENT__LIMIT: return getLimit(); case SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET: return getLimitOffset(); } return super.eGet(featureID, resolve, coreType); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public void eSet(int featureID, Object newValue) { switch (featureID) { case SqliteModelPackage.SELECT_STATEMENT__CORE: setCore((SelectCoreExpression)newValue); return; case SqliteModelPackage.SELECT_STATEMENT__ORDERBY: setOrderby((OrderingTermList)newValue); return; case SqliteModelPackage.SELECT_STATEMENT__LIMIT: setLimit((Expression)newValue); return; case SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET: setLimitOffset((Expression)newValue); return; } super.eSet(featureID, newValue); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case SqliteModelPackage.SELECT_STATEMENT__CORE: setCore((SelectCoreExpression)null); return; case SqliteModelPackage.SELECT_STATEMENT__ORDERBY: setOrderby((OrderingTermList)null); return; case SqliteModelPackage.SELECT_STATEMENT__LIMIT: setLimit((Expression)null); return; case SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET: setLimitOffset((Expression)null); return; } super.eUnset(featureID); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case SqliteModelPackage.SELECT_STATEMENT__CORE: return core != null; case SqliteModelPackage.SELECT_STATEMENT__ORDERBY: return orderby != null; case SqliteModelPackage.SELECT_STATEMENT__LIMIT: return limit != null; case SqliteModelPackage.SELECT_STATEMENT__LIMIT_OFFSET: return limitOffset != null; } return super.eIsSet(featureID); } } //SelectStatementImpl