/**
* <copyright>
* </copyright>
*
* $Id: SecondaryTableImpl.java,v 1.5 2011/10/25 13:25:23 mtaal Exp $
*/
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.PrimaryKeyJoinColumn;
import org.eclipse.emf.texo.orm.annotations.model.orm.SecondaryTable;
import org.eclipse.emf.texo.orm.annotations.model.orm.UniqueConstraint;
import org.eclipse.emf.texo.orm.annotator.BaseOrmAnnotationImpl;
/**
* <!-- begin-user-doc --> An implementation of the model object '<em><b>Secondary Table</b></em>'. <!-- end-user-doc
* -->
* <p>
* The following features are implemented:
* <ul>
* <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.SecondaryTableImpl#getPrimaryKeyJoinColumn <em>Primary
* Key Join Column</em>}</li>
* <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.SecondaryTableImpl#getUniqueConstraint <em>Unique
* Constraint</em>}</li>
* <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.SecondaryTableImpl#getCatalog <em>Catalog</em>}</li>
* <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.SecondaryTableImpl#getName <em>Name</em>}</li>
* <li>{@link org.eclipse.emf.texo.orm.annotations.model.orm.impl.SecondaryTableImpl#getSchema <em>Schema</em>}</li>
* </ul>
* </p>
*
* @generated
*/
public class SecondaryTableImpl extends BaseOrmAnnotationImpl implements SecondaryTable {
/**
* The cached value of the '{@link #getPrimaryKeyJoinColumn() <em>Primary Key Join Column</em>}' containment reference list.
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @see #getPrimaryKeyJoinColumn()
* @generated
* @ordered
*/
protected EList<PrimaryKeyJoinColumn> primaryKeyJoinColumn;
/**
* The cached value of the '{@link #getUniqueConstraint() <em>Unique Constraint</em>}' containment reference list.
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @see #getUniqueConstraint()
* @generated
* @ordered
*/
protected EList<UniqueConstraint> uniqueConstraint;
/**
* The default value of the '{@link #getCatalog() <em>Catalog</em>}' attribute.
* <!-- begin-user-doc --> <!--
* end-user-doc -->
* @see #getCatalog()
* @generated
* @ordered
*/
protected static final String CATALOG_EDEFAULT = null;
/**
* The cached value of the '{@link #getCatalog() <em>Catalog</em>}' attribute.
* <!-- begin-user-doc --> <!--
* end-user-doc -->
* @see #getCatalog()
* @generated
* @ordered
*/
protected String catalog = CATALOG_EDEFAULT;
/**
* The default value of the '{@link #getCreationSuffix() <em>Creation Suffix</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getCreationSuffix()
* @generated
* @ordered
*/
protected static final String CREATION_SUFFIX_EDEFAULT = null;
/**
* The cached value of the '{@link #getCreationSuffix() <em>Creation Suffix</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getCreationSuffix()
* @generated
* @ordered
*/
protected String creationSuffix = CREATION_SUFFIX_EDEFAULT;
/**
* This is true if the Creation Suffix attribute has been set.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
* @ordered
*/
protected boolean creationSuffixESet;
/**
* 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;
/**
* The default value of the '{@link #getSchema() <em>Schema</em>}' attribute.
* <!-- begin-user-doc --> <!--
* end-user-doc -->
* @see #getSchema()
* @generated
* @ordered
*/
protected static final String SCHEMA_EDEFAULT = null;
/**
* The cached value of the '{@link #getSchema() <em>Schema</em>}' attribute. <!-- begin-user-doc --> <!-- end-user-doc
* -->
*
* @see #getSchema()
* @generated
* @ordered
*/
protected String schema = SCHEMA_EDEFAULT;
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
protected SecondaryTableImpl() {
super();
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass() {
return OrmPackage.eINSTANCE.getSecondaryTable();
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
public EList<PrimaryKeyJoinColumn> getPrimaryKeyJoinColumn() {
if (primaryKeyJoinColumn == null) {
primaryKeyJoinColumn = new EObjectContainmentEList<PrimaryKeyJoinColumn>(PrimaryKeyJoinColumn.class, this, OrmPackage.SECONDARY_TABLE__PRIMARY_KEY_JOIN_COLUMN);
}
return primaryKeyJoinColumn;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
public EList<UniqueConstraint> getUniqueConstraint() {
if (uniqueConstraint == null) {
uniqueConstraint = new EObjectContainmentEList<UniqueConstraint>(UniqueConstraint.class, this, OrmPackage.SECONDARY_TABLE__UNIQUE_CONSTRAINT);
}
return uniqueConstraint;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
public String getCatalog() {
return catalog;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
public void setCatalog(String newCatalog) {
String oldCatalog = catalog;
catalog = newCatalog;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.SECONDARY_TABLE__CATALOG, oldCatalog, catalog));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public String getCreationSuffix() {
return creationSuffix;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setCreationSuffix(String newCreationSuffix) {
String oldCreationSuffix = creationSuffix;
creationSuffix = newCreationSuffix;
boolean oldCreationSuffixESet = creationSuffixESet;
creationSuffixESet = true;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.SECONDARY_TABLE__CREATION_SUFFIX, oldCreationSuffix, creationSuffix, !oldCreationSuffixESet));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void unsetCreationSuffix() {
String oldCreationSuffix = creationSuffix;
boolean oldCreationSuffixESet = creationSuffixESet;
creationSuffix = CREATION_SUFFIX_EDEFAULT;
creationSuffixESet = false;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.UNSET, OrmPackage.SECONDARY_TABLE__CREATION_SUFFIX, oldCreationSuffix, CREATION_SUFFIX_EDEFAULT, oldCreationSuffixESet));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean isSetCreationSuffix() {
return creationSuffixESet;
}
/**
* <!-- 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.SECONDARY_TABLE__NAME, oldName, name));
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
public String getSchema() {
return schema;
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
public void setSchema(String newSchema) {
String oldSchema = schema;
schema = newSchema;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.SECONDARY_TABLE__SCHEMA, oldSchema, schema));
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) {
switch (featureID) {
case OrmPackage.SECONDARY_TABLE__PRIMARY_KEY_JOIN_COLUMN:
return ((InternalEList<?>)getPrimaryKeyJoinColumn()).basicRemove(otherEnd, msgs);
case OrmPackage.SECONDARY_TABLE__UNIQUE_CONSTRAINT:
return ((InternalEList<?>)getUniqueConstraint()).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.SECONDARY_TABLE__PRIMARY_KEY_JOIN_COLUMN:
return getPrimaryKeyJoinColumn();
case OrmPackage.SECONDARY_TABLE__UNIQUE_CONSTRAINT:
return getUniqueConstraint();
case OrmPackage.SECONDARY_TABLE__CATALOG:
return getCatalog();
case OrmPackage.SECONDARY_TABLE__CREATION_SUFFIX:
return getCreationSuffix();
case OrmPackage.SECONDARY_TABLE__NAME:
return getName();
case OrmPackage.SECONDARY_TABLE__SCHEMA:
return getSchema();
}
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.SECONDARY_TABLE__PRIMARY_KEY_JOIN_COLUMN:
getPrimaryKeyJoinColumn().clear();
getPrimaryKeyJoinColumn().addAll((Collection<? extends PrimaryKeyJoinColumn>)newValue);
return;
case OrmPackage.SECONDARY_TABLE__UNIQUE_CONSTRAINT:
getUniqueConstraint().clear();
getUniqueConstraint().addAll((Collection<? extends UniqueConstraint>)newValue);
return;
case OrmPackage.SECONDARY_TABLE__CATALOG:
setCatalog((String)newValue);
return;
case OrmPackage.SECONDARY_TABLE__CREATION_SUFFIX:
setCreationSuffix((String)newValue);
return;
case OrmPackage.SECONDARY_TABLE__NAME:
setName((String)newValue);
return;
case OrmPackage.SECONDARY_TABLE__SCHEMA:
setSchema((String)newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(int featureID) {
switch (featureID) {
case OrmPackage.SECONDARY_TABLE__PRIMARY_KEY_JOIN_COLUMN:
getPrimaryKeyJoinColumn().clear();
return;
case OrmPackage.SECONDARY_TABLE__UNIQUE_CONSTRAINT:
getUniqueConstraint().clear();
return;
case OrmPackage.SECONDARY_TABLE__CATALOG:
setCatalog(CATALOG_EDEFAULT);
return;
case OrmPackage.SECONDARY_TABLE__CREATION_SUFFIX:
unsetCreationSuffix();
return;
case OrmPackage.SECONDARY_TABLE__NAME:
setName(NAME_EDEFAULT);
return;
case OrmPackage.SECONDARY_TABLE__SCHEMA:
setSchema(SCHEMA_EDEFAULT);
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc --> <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(int featureID) {
switch (featureID) {
case OrmPackage.SECONDARY_TABLE__PRIMARY_KEY_JOIN_COLUMN:
return primaryKeyJoinColumn != null && !primaryKeyJoinColumn.isEmpty();
case OrmPackage.SECONDARY_TABLE__UNIQUE_CONSTRAINT:
return uniqueConstraint != null && !uniqueConstraint.isEmpty();
case OrmPackage.SECONDARY_TABLE__CATALOG:
return CATALOG_EDEFAULT == null ? catalog != null : !CATALOG_EDEFAULT.equals(catalog);
case OrmPackage.SECONDARY_TABLE__CREATION_SUFFIX:
return isSetCreationSuffix();
case OrmPackage.SECONDARY_TABLE__NAME:
return NAME_EDEFAULT == null ? name != null : !NAME_EDEFAULT.equals(name);
case OrmPackage.SECONDARY_TABLE__SCHEMA:
return SCHEMA_EDEFAULT == null ? schema != null : !SCHEMA_EDEFAULT.equals(schema);
}
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(" (catalog: "); //$NON-NLS-1$
result.append(catalog);
result.append(", creationSuffix: "); //$NON-NLS-1$
if (creationSuffixESet) result.append(creationSuffix); else result.append("<unset>"); //$NON-NLS-1$
result.append(", name: "); //$NON-NLS-1$
result.append(name);
result.append(", schema: "); //$NON-NLS-1$
result.append(schema);
result.append(')');
return result.toString();
}
} // SecondaryTableImpl