/*
* JBoss, Home of Professional Open Source.
*
* See the LEGAL.txt file distributed with this work for information regarding copyright ownership and licensing.
*
* See the AUTHORS.txt file distributed with this work for a full listing of individual contributors.
*/
package org.teiid.designer.metamodels.relational.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.EStructuralFeature;
import org.eclipse.emf.ecore.InternalEObject;
import org.eclipse.emf.ecore.impl.ENotificationImpl;
import org.eclipse.emf.ecore.util.EObjectContainmentWithInverseEList;
import org.eclipse.emf.ecore.util.EcoreUtil;
import org.eclipse.emf.ecore.util.InternalEList;
import org.teiid.designer.metamodels.relational.Catalog;
import org.teiid.designer.metamodels.relational.Index;
import org.teiid.designer.metamodels.relational.LogicalRelationship;
import org.teiid.designer.metamodels.relational.Procedure;
import org.teiid.designer.metamodels.relational.RelationalPackage;
import org.teiid.designer.metamodels.relational.Schema;
import org.teiid.designer.metamodels.relational.Table;
/**
* <!-- begin-user-doc -->
* An implementation of the model object '<em><b>Schema</b></em>'.
* <!-- end-user-doc -->
* <p>
* The following features are implemented:
* <ul>
* <li>{@link org.teiid.designer.metamodels.relational.impl.SchemaImpl#getTables <em>Tables</em>}</li>
* <li>{@link org.teiid.designer.metamodels.relational.impl.SchemaImpl#getCatalog <em>Catalog</em>}</li>
* <li>{@link org.teiid.designer.metamodels.relational.impl.SchemaImpl#getProcedures <em>Procedures</em>}</li>
* <li>{@link org.teiid.designer.metamodels.relational.impl.SchemaImpl#getIndexes <em>Indexes</em>}</li>
* <li>{@link org.teiid.designer.metamodels.relational.impl.SchemaImpl#getLogicalRelationships <em>Logical Relationships</em>}</li>
* </ul>
* </p>
*
* @generated
*
* @since 8.0
*/
public class SchemaImpl extends RelationalEntityImpl implements Schema {
/**
* The cached value of the '{@link #getTables() <em>Tables</em>}' containment reference list.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getTables()
* @generated
* @ordered
*/
protected EList tables = null;
/**
* The cached value of the '{@link #getProcedures() <em>Procedures</em>}' containment reference list.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getProcedures()
* @generated
* @ordered
*/
protected EList procedures = null;
/**
* The cached value of the '{@link #getIndexes() <em>Indexes</em>}' containment reference list.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getIndexes()
* @generated
* @ordered
*/
protected EList indexes = null;
/**
* The cached value of the '{@link #getLogicalRelationships() <em>Logical Relationships</em>}' containment reference list.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getLogicalRelationships()
* @generated
* @ordered
*/
protected EList logicalRelationships = null;
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected SchemaImpl() {
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass() {
return RelationalPackage.eINSTANCE.getSchema();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public EList getTables() {
if (tables == null) {
tables = new EObjectContainmentWithInverseEList(Table.class, this, RelationalPackage.SCHEMA__TABLES, RelationalPackage.TABLE__SCHEMA);
}
return tables;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Catalog getCatalog() {
if (eContainerFeatureID != RelationalPackage.SCHEMA__CATALOG) return null;
return (Catalog)eContainer;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void setCatalog(Catalog newCatalog) {
if (newCatalog != eContainer || (eContainerFeatureID != RelationalPackage.SCHEMA__CATALOG && newCatalog != null)) {
if (EcoreUtil.isAncestor(this, newCatalog))
throw new IllegalArgumentException("Recursive containment not allowed for " + toString()); //$NON-NLS-1$
NotificationChain msgs = null;
if (eContainer != null)
msgs = eBasicRemoveFromContainer(msgs);
if (newCatalog != null)
msgs = ((InternalEObject)newCatalog).eInverseAdd(this, RelationalPackage.CATALOG__SCHEMAS, Catalog.class, msgs);
msgs = eBasicSetContainer((InternalEObject)newCatalog, RelationalPackage.SCHEMA__CATALOG, msgs);
if (msgs != null) msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, RelationalPackage.SCHEMA__CATALOG, newCatalog, newCatalog));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public EList getProcedures() {
if (procedures == null) {
procedures = new EObjectContainmentWithInverseEList(Procedure.class, this, RelationalPackage.SCHEMA__PROCEDURES, RelationalPackage.PROCEDURE__SCHEMA);
}
return procedures;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public EList getIndexes() {
if (indexes == null) {
indexes = new EObjectContainmentWithInverseEList(Index.class, this, RelationalPackage.SCHEMA__INDEXES, RelationalPackage.INDEX__SCHEMA);
}
return indexes;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public EList getLogicalRelationships() {
if (logicalRelationships == null) {
logicalRelationships = new EObjectContainmentWithInverseEList(LogicalRelationship.class, this, RelationalPackage.SCHEMA__LOGICAL_RELATIONSHIPS, RelationalPackage.LOGICAL_RELATIONSHIP__SCHEMA);
}
return logicalRelationships;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseAdd(InternalEObject otherEnd, int featureID, Class baseClass, NotificationChain msgs) {
if (featureID >= 0) {
switch (eDerivedStructuralFeatureID(featureID, baseClass)) {
case RelationalPackage.SCHEMA__TABLES:
return ((InternalEList)getTables()).basicAdd(otherEnd, msgs);
case RelationalPackage.SCHEMA__CATALOG:
if (eContainer != null)
msgs = eBasicRemoveFromContainer(msgs);
return eBasicSetContainer(otherEnd, RelationalPackage.SCHEMA__CATALOG, msgs);
case RelationalPackage.SCHEMA__PROCEDURES:
return ((InternalEList)getProcedures()).basicAdd(otherEnd, msgs);
case RelationalPackage.SCHEMA__INDEXES:
return ((InternalEList)getIndexes()).basicAdd(otherEnd, msgs);
case RelationalPackage.SCHEMA__LOGICAL_RELATIONSHIPS:
return ((InternalEList)getLogicalRelationships()).basicAdd(otherEnd, msgs);
default:
return eDynamicInverseAdd(otherEnd, featureID, baseClass, msgs);
}
}
if (eContainer != null)
msgs = eBasicRemoveFromContainer(msgs);
return eBasicSetContainer(otherEnd, featureID, msgs);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, Class baseClass, NotificationChain msgs) {
if (featureID >= 0) {
switch (eDerivedStructuralFeatureID(featureID, baseClass)) {
case RelationalPackage.SCHEMA__TABLES:
return ((InternalEList)getTables()).basicRemove(otherEnd, msgs);
case RelationalPackage.SCHEMA__CATALOG:
return eBasicSetContainer(null, RelationalPackage.SCHEMA__CATALOG, msgs);
case RelationalPackage.SCHEMA__PROCEDURES:
return ((InternalEList)getProcedures()).basicRemove(otherEnd, msgs);
case RelationalPackage.SCHEMA__INDEXES:
return ((InternalEList)getIndexes()).basicRemove(otherEnd, msgs);
case RelationalPackage.SCHEMA__LOGICAL_RELATIONSHIPS:
return ((InternalEList)getLogicalRelationships()).basicRemove(otherEnd, msgs);
default:
return eDynamicInverseRemove(otherEnd, featureID, baseClass, msgs);
}
}
return eBasicSetContainer(null, featureID, msgs);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eBasicRemoveFromContainer(NotificationChain msgs) {
if (eContainerFeatureID >= 0) {
switch (eContainerFeatureID) {
case RelationalPackage.SCHEMA__CATALOG:
return eContainer.eInverseRemove(this, RelationalPackage.CATALOG__SCHEMAS, Catalog.class, msgs);
default:
return eDynamicBasicRemoveFromContainer(msgs);
}
}
return eContainer.eInverseRemove(this, EOPPOSITE_FEATURE_BASE - eContainerFeatureID, null, msgs);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Object eGet(EStructuralFeature eFeature, boolean resolve) {
switch (eDerivedStructuralFeatureID(eFeature)) {
case RelationalPackage.SCHEMA__NAME:
return getName();
case RelationalPackage.SCHEMA__NAME_IN_SOURCE:
return getNameInSource();
case RelationalPackage.SCHEMA__TABLES:
return getTables();
case RelationalPackage.SCHEMA__CATALOG:
return getCatalog();
case RelationalPackage.SCHEMA__PROCEDURES:
return getProcedures();
case RelationalPackage.SCHEMA__INDEXES:
return getIndexes();
case RelationalPackage.SCHEMA__LOGICAL_RELATIONSHIPS:
return getLogicalRelationships();
}
return eDynamicGet(eFeature, resolve);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eSet(EStructuralFeature eFeature, Object newValue) {
switch (eDerivedStructuralFeatureID(eFeature)) {
case RelationalPackage.SCHEMA__NAME:
setName((String)newValue);
return;
case RelationalPackage.SCHEMA__NAME_IN_SOURCE:
setNameInSource((String)newValue);
return;
case RelationalPackage.SCHEMA__TABLES:
getTables().clear();
getTables().addAll((Collection)newValue);
return;
case RelationalPackage.SCHEMA__CATALOG:
setCatalog((Catalog)newValue);
return;
case RelationalPackage.SCHEMA__PROCEDURES:
getProcedures().clear();
getProcedures().addAll((Collection)newValue);
return;
case RelationalPackage.SCHEMA__INDEXES:
getIndexes().clear();
getIndexes().addAll((Collection)newValue);
return;
case RelationalPackage.SCHEMA__LOGICAL_RELATIONSHIPS:
getLogicalRelationships().clear();
getLogicalRelationships().addAll((Collection)newValue);
return;
}
eDynamicSet(eFeature, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(EStructuralFeature eFeature) {
switch (eDerivedStructuralFeatureID(eFeature)) {
case RelationalPackage.SCHEMA__NAME:
setName(NAME_EDEFAULT);
return;
case RelationalPackage.SCHEMA__NAME_IN_SOURCE:
setNameInSource(NAME_IN_SOURCE_EDEFAULT);
return;
case RelationalPackage.SCHEMA__TABLES:
getTables().clear();
return;
case RelationalPackage.SCHEMA__CATALOG:
setCatalog((Catalog)null);
return;
case RelationalPackage.SCHEMA__PROCEDURES:
getProcedures().clear();
return;
case RelationalPackage.SCHEMA__INDEXES:
getIndexes().clear();
return;
case RelationalPackage.SCHEMA__LOGICAL_RELATIONSHIPS:
getLogicalRelationships().clear();
return;
}
eDynamicUnset(eFeature);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(EStructuralFeature eFeature) {
switch (eDerivedStructuralFeatureID(eFeature)) {
case RelationalPackage.SCHEMA__NAME:
return NAME_EDEFAULT == null ? name != null : !NAME_EDEFAULT.equals(name);
case RelationalPackage.SCHEMA__NAME_IN_SOURCE:
return NAME_IN_SOURCE_EDEFAULT == null ? nameInSource != null : !NAME_IN_SOURCE_EDEFAULT.equals(nameInSource);
case RelationalPackage.SCHEMA__TABLES:
return tables != null && !tables.isEmpty();
case RelationalPackage.SCHEMA__CATALOG:
return getCatalog() != null;
case RelationalPackage.SCHEMA__PROCEDURES:
return procedures != null && !procedures.isEmpty();
case RelationalPackage.SCHEMA__INDEXES:
return indexes != null && !indexes.isEmpty();
case RelationalPackage.SCHEMA__LOGICAL_RELATIONSHIPS:
return logicalRelationships != null && !logicalRelationships.isEmpty();
}
return eDynamicIsSet(eFeature);
}
} //SchemaImpl