/** * <copyright> * </copyright> * * $Id$ */ package org.eclipse.emf.texo.orm.annotations.model.orm.impl; import java.util.Collection; import org.eclipse.emf.common.notify.Notification; 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.ENotificationImpl; import org.eclipse.emf.ecore.util.EObjectContainmentEList; import org.eclipse.emf.ecore.util.InternalEList; import org.eclipse.emf.texo.orm.annotations.model.orm.OrmPackage; import org.eclipse.emf.texo.orm.annotations.model.orm.PlsqlParameter; import org.eclipse.emf.texo.orm.annotations.model.orm.PlsqlRecord; import org.eclipse.emf.texo.orm.annotator.BaseOrmAnnotationImpl; /** * <!-- begin-user-doc --> * An implementation of the model object '<em><b>Plsql Record</b></em>'. * <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.PlsqlRecordImpl#getField <em>Field</em>}</li> * <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.PlsqlRecordImpl#getCompatibleType <em>Compatible Type</em>}</li> * <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.PlsqlRecordImpl#getJavaType <em>Java Type</em>}</li> * <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.PlsqlRecordImpl#getName <em>Name</em>}</li> * </ul> * </p> * * @generated */ public class PlsqlRecordImpl extends BaseOrmAnnotationImpl implements PlsqlRecord { /** * The cached value of the '{@link #getField() <em>Field</em>}' containment reference list. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getField() * @generated * @ordered */ protected EList<PlsqlParameter> field; /** * The default value of the '{@link #getCompatibleType() <em>Compatible Type</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getCompatibleType() * @generated * @ordered */ protected static final String COMPATIBLE_TYPE_EDEFAULT = null; /** * The cached value of the '{@link #getCompatibleType() <em>Compatible Type</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getCompatibleType() * @generated * @ordered */ protected String compatibleType = COMPATIBLE_TYPE_EDEFAULT; /** * The default value of the '{@link #getJavaType() <em>Java Type</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getJavaType() * @generated * @ordered */ protected static final String JAVA_TYPE_EDEFAULT = null; /** * The cached value of the '{@link #getJavaType() <em>Java Type</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getJavaType() * @generated * @ordered */ protected String javaType = JAVA_TYPE_EDEFAULT; /** * The default value of the '{@link #getName() <em>Name</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getName() * @generated * @ordered */ protected static final String NAME_EDEFAULT = null; /** * The cached value of the '{@link #getName() <em>Name</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getName() * @generated * @ordered */ protected String name = NAME_EDEFAULT; /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ protected PlsqlRecordImpl() { super(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return OrmPackage.eINSTANCE.getPlsqlRecord(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public EList<PlsqlParameter> getField() { if (field == null) { field = new EObjectContainmentEList<PlsqlParameter>(PlsqlParameter.class, this, OrmPackage.PLSQL_RECORD__FIELD); } return field; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public String getCompatibleType() { return compatibleType; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setCompatibleType(String newCompatibleType) { String oldCompatibleType = compatibleType; compatibleType = newCompatibleType; if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.PLSQL_RECORD__COMPATIBLE_TYPE, oldCompatibleType, compatibleType)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public String getJavaType() { return javaType; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setJavaType(String newJavaType) { String oldJavaType = javaType; javaType = newJavaType; if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.PLSQL_RECORD__JAVA_TYPE, oldJavaType, javaType)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public String getName() { return name; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setName(String newName) { String oldName = name; name = newName; if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.PLSQL_RECORD__NAME, oldName, name)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case OrmPackage.PLSQL_RECORD__FIELD: return ((InternalEList<?>)getField()).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 OrmPackage.PLSQL_RECORD__FIELD: return getField(); case OrmPackage.PLSQL_RECORD__COMPATIBLE_TYPE: return getCompatibleType(); case OrmPackage.PLSQL_RECORD__JAVA_TYPE: return getJavaType(); case OrmPackage.PLSQL_RECORD__NAME: return getName(); } 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 OrmPackage.PLSQL_RECORD__FIELD: getField().clear(); getField().addAll((Collection<? extends PlsqlParameter>)newValue); return; case OrmPackage.PLSQL_RECORD__COMPATIBLE_TYPE: setCompatibleType((String)newValue); return; case OrmPackage.PLSQL_RECORD__JAVA_TYPE: setJavaType((String)newValue); return; case OrmPackage.PLSQL_RECORD__NAME: setName((String)newValue); return; } super.eSet(featureID, newValue); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case OrmPackage.PLSQL_RECORD__FIELD: getField().clear(); return; case OrmPackage.PLSQL_RECORD__COMPATIBLE_TYPE: setCompatibleType(COMPATIBLE_TYPE_EDEFAULT); return; case OrmPackage.PLSQL_RECORD__JAVA_TYPE: setJavaType(JAVA_TYPE_EDEFAULT); return; case OrmPackage.PLSQL_RECORD__NAME: setName(NAME_EDEFAULT); return; } super.eUnset(featureID); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case OrmPackage.PLSQL_RECORD__FIELD: return field != null && !field.isEmpty(); case OrmPackage.PLSQL_RECORD__COMPATIBLE_TYPE: return COMPATIBLE_TYPE_EDEFAULT == null ? compatibleType != null : !COMPATIBLE_TYPE_EDEFAULT.equals(compatibleType); case OrmPackage.PLSQL_RECORD__JAVA_TYPE: return JAVA_TYPE_EDEFAULT == null ? javaType != null : !JAVA_TYPE_EDEFAULT.equals(javaType); case OrmPackage.PLSQL_RECORD__NAME: return NAME_EDEFAULT == null ? name != null : !NAME_EDEFAULT.equals(name); } return super.eIsSet(featureID); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public String toString() { if (eIsProxy()) return super.toString(); StringBuffer result = new StringBuffer(super.toString()); result.append(" (compatibleType: "); //$NON-NLS-1$ result.append(compatibleType); result.append(", javaType: "); //$NON-NLS-1$ result.append(javaType); result.append(", name: "); //$NON-NLS-1$ result.append(name); result.append(')'); return result.toString(); } } //PlsqlRecordImpl