/*
* Copyright (c) 2011, IRISA
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* * Neither the name of IRISA nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
* WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
package net.sf.orcc.backends.llvm.tta.architecture.impl;
import net.sf.orcc.backends.llvm.tta.architecture.ArchitecturePackage;
import net.sf.orcc.backends.llvm.tta.architecture.FuPort;
import net.sf.orcc.backends.llvm.tta.architecture.FunctionUnit;
import net.sf.orcc.backends.llvm.tta.architecture.TermUnit;
import org.eclipse.emf.common.notify.Notification;
import org.eclipse.emf.ecore.EClass;
import org.eclipse.emf.ecore.InternalEObject;
import org.eclipse.emf.ecore.impl.ENotificationImpl;
import org.eclipse.emf.ecore.impl.EObjectImpl;
/**
* <!-- begin-user-doc -->
* An implementation of the model object '<em><b>Term Unit</b></em>'.
* <!-- end-user-doc -->
* <p>
* The following features are implemented:
* <ul>
* <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.TermUnitImpl#getFunctionUnit <em>Function Unit</em>}</li>
* <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.TermUnitImpl#getPort <em>Port</em>}</li>
* </ul>
* </p>
*
* @generated
*/
public class TermUnitImpl extends EObjectImpl implements TermUnit {
/**
* The cached value of the '{@link #getFunctionUnit() <em>Function Unit</em>}' reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getFunctionUnit()
* @generated
* @ordered
*/
protected FunctionUnit functionUnit;
/**
* The cached value of the '{@link #getPort() <em>Port</em>}' reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getPort()
* @generated
* @ordered
*/
protected FuPort port;
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected TermUnitImpl() {
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass() {
return ArchitecturePackage.Literals.TERM_UNIT;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public FunctionUnit getFunctionUnit() {
if (functionUnit != null && functionUnit.eIsProxy()) {
InternalEObject oldFunctionUnit = (InternalEObject) functionUnit;
functionUnit = (FunctionUnit) eResolveProxy(oldFunctionUnit);
if (functionUnit != oldFunctionUnit) {
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.RESOLVE,
ArchitecturePackage.TERM_UNIT__FUNCTION_UNIT,
oldFunctionUnit, functionUnit));
}
}
return functionUnit;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public FunctionUnit basicGetFunctionUnit() {
return functionUnit;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setFunctionUnit(FunctionUnit newFunctionUnit) {
FunctionUnit oldFunctionUnit = functionUnit;
functionUnit = newFunctionUnit;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET,
ArchitecturePackage.TERM_UNIT__FUNCTION_UNIT,
oldFunctionUnit, functionUnit));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public FuPort getPort() {
if (port != null && port.eIsProxy()) {
InternalEObject oldPort = (InternalEObject) port;
port = (FuPort) eResolveProxy(oldPort);
if (port != oldPort) {
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.RESOLVE,
ArchitecturePackage.TERM_UNIT__PORT, oldPort, port));
}
}
return port;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public FuPort basicGetPort() {
return port;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setPort(FuPort newPort) {
FuPort oldPort = port;
port = newPort;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET,
ArchitecturePackage.TERM_UNIT__PORT, oldPort, port));
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*/
public boolean isTermBool() {
return false;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*/
public boolean isTermUnit() {
return true;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Object eGet(int featureID, boolean resolve, boolean coreType) {
switch (featureID) {
case ArchitecturePackage.TERM_UNIT__FUNCTION_UNIT:
if (resolve)
return getFunctionUnit();
return basicGetFunctionUnit();
case ArchitecturePackage.TERM_UNIT__PORT:
if (resolve)
return getPort();
return basicGetPort();
}
return super.eGet(featureID, resolve, coreType);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eSet(int featureID, Object newValue) {
switch (featureID) {
case ArchitecturePackage.TERM_UNIT__FUNCTION_UNIT:
setFunctionUnit((FunctionUnit) newValue);
return;
case ArchitecturePackage.TERM_UNIT__PORT:
setPort((FuPort) newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(int featureID) {
switch (featureID) {
case ArchitecturePackage.TERM_UNIT__FUNCTION_UNIT:
setFunctionUnit((FunctionUnit) null);
return;
case ArchitecturePackage.TERM_UNIT__PORT:
setPort((FuPort) null);
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(int featureID) {
switch (featureID) {
case ArchitecturePackage.TERM_UNIT__FUNCTION_UNIT:
return functionUnit != null;
case ArchitecturePackage.TERM_UNIT__PORT:
return port != null;
}
return super.eIsSet(featureID);
}
} //TermUnitImpl