/* * 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.Reads; 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>Reads</b></em>'. * <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.ReadsImpl#getStartCycle <em>Start Cycle</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.ReadsImpl#getCycles <em>Cycles</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.ReadsImpl#getPort <em>Port</em>}</li> * </ul> * </p> * * @generated */ public class ReadsImpl extends EObjectImpl implements Reads { /** * The default value of the '{@link #getStartCycle() <em>Start Cycle</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getStartCycle() * @generated * @ordered */ protected static final int START_CYCLE_EDEFAULT = 0; /** * The cached value of the '{@link #getStartCycle() <em>Start Cycle</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getStartCycle() * @generated * @ordered */ protected int startCycle = START_CYCLE_EDEFAULT; /** * The default value of the '{@link #getCycles() <em>Cycles</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getCycles() * @generated * @ordered */ protected static final int CYCLES_EDEFAULT = 0; /** * The cached value of the '{@link #getCycles() <em>Cycles</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getCycles() * @generated * @ordered */ protected int cycles = CYCLES_EDEFAULT; /** * 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 ReadsImpl() { super(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return ArchitecturePackage.Literals.READS; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public int getStartCycle() { return startCycle; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setStartCycle(int newStartCycle) { int oldStartCycle = startCycle; startCycle = newStartCycle; if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, ArchitecturePackage.READS__START_CYCLE, oldStartCycle, startCycle)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public int getCycles() { return cycles; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setCycles(int newCycles) { int oldCycles = cycles; cycles = newCycles; if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, ArchitecturePackage.READS__CYCLES, oldCycles, cycles)); } /** * <!-- 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.READS__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.READS__PORT, oldPort, port)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> */ public boolean isReads() { return true; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> */ public boolean isWrites() { return false; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> */ public boolean isResource() { return false; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public Object eGet(int featureID, boolean resolve, boolean coreType) { switch (featureID) { case ArchitecturePackage.READS__START_CYCLE: return getStartCycle(); case ArchitecturePackage.READS__CYCLES: return getCycles(); case ArchitecturePackage.READS__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.READS__START_CYCLE: setStartCycle((Integer) newValue); return; case ArchitecturePackage.READS__CYCLES: setCycles((Integer) newValue); return; case ArchitecturePackage.READS__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.READS__START_CYCLE: setStartCycle(START_CYCLE_EDEFAULT); return; case ArchitecturePackage.READS__CYCLES: setCycles(CYCLES_EDEFAULT); return; case ArchitecturePackage.READS__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.READS__START_CYCLE: return startCycle != START_CYCLE_EDEFAULT; case ArchitecturePackage.READS__CYCLES: return cycles != CYCLES_EDEFAULT; case ArchitecturePackage.READS__PORT: return port != null; } 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(" (startCycle: "); result.append(startCycle); result.append(", cycles: "); result.append(cycles); result.append(')'); return result.toString(); } } //ReadsImpl