/** * <copyright> * Copyright (c) 2009-2012, IETR/INSA of Rennes * 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 the IETR/INSA of Rennes 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. * </copyright> */ package net.sf.orcc.backends.llvm.tta.architecture.impl; import java.util.Collection; import java.util.HashMap; import java.util.Map; import net.sf.orcc.OrccRuntimeException; import net.sf.orcc.backends.llvm.tta.architecture.ArchitecturePackage; import net.sf.orcc.backends.llvm.tta.architecture.Component; import net.sf.orcc.backends.llvm.tta.architecture.Design; import net.sf.orcc.backends.llvm.tta.architecture.Implementation; import net.sf.orcc.backends.llvm.tta.architecture.Memory; import net.sf.orcc.backends.llvm.tta.architecture.Port; import net.sf.orcc.backends.llvm.tta.architecture.Processor; import net.sf.orcc.backends.llvm.tta.architecture.Signal; import net.sf.orcc.graph.Edge; import net.sf.orcc.graph.Vertex; import net.sf.orcc.graph.impl.GraphImpl; 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.common.util.EMap; 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.EObjectResolvingEList; import org.eclipse.emf.ecore.util.EcoreEMap; import org.eclipse.emf.ecore.util.InternalEList; /** * <!-- begin-user-doc --> An implementation of the model object ' * <em><b>Design</b></em>'. <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.DesignImpl#getName <em>Name</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.DesignImpl#getComponents <em>Components</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.DesignImpl#getProcessors <em>Processors</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.DesignImpl#getSharedMemories <em>Shared Memories</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.DesignImpl#getSignals <em>Signals</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.DesignImpl#getInputs <em>Inputs</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.DesignImpl#getOutputs <em>Outputs</em>}</li> * <li>{@link net.sf.orcc.backends.llvm.tta.architecture.impl.DesignImpl#getHardwareDatabase <em>Hardware Database</em>}</li> * </ul> * </p> * * @generated */ public class DesignImpl extends GraphImpl implements Design { /** * 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 cached value of the '{@link #getComponents() <em>Components</em>}' reference list. * <!-- begin-user-doc --> <!-- end-user-doc --> * @see #getComponents() * @generated * @ordered */ protected EList<Component> components; /** * The cached value of the '{@link #getProcessors() <em>Processors</em>}' reference list. * <!-- begin-user-doc --> <!-- end-user-doc --> * @see #getProcessors() * @generated * @ordered */ protected EList<Processor> processors; /** * The cached value of the '{@link #getSharedMemories() <em>Shared Memories</em>}' reference list. * <!-- begin-user-doc --> <!-- * end-user-doc --> * @see #getSharedMemories() * @generated * @ordered */ protected EList<Memory> sharedMemories; /** * The cached value of the '{@link #getSignals() <em>Signals</em>}' reference list. * <!-- begin-user-doc --> <!-- end-user-doc --> * @see #getSignals() * @generated * @ordered */ protected EList<Signal> signals; /** * The cached value of the '{@link #getInputs() <em>Inputs</em>}' reference list. * <!-- begin-user-doc --> <!-- end-user-doc --> * @see #getInputs() * @generated * @ordered */ protected EList<Port> inputs; /** * The cached value of the '{@link #getOutputs() <em>Outputs</em>}' reference list. * <!-- begin-user-doc --> <!-- end-user-doc --> * @see #getOutputs() * @generated * @ordered */ protected EList<Port> outputs; /** * The cached value of the '{@link #getHardwareDatabase() <em>Hardware Database</em>}' map. * <!-- begin-user-doc --> <!-- * end-user-doc --> * @see #getHardwareDatabase() * @generated * @ordered */ protected EMap<String, Implementation> hardwareDatabase; /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ protected DesignImpl() { super(); } @Override public void add(Edge edge) { if (edge instanceof Signal) { getSignals().add((Signal) edge); } else if (edge instanceof Memory) { getSharedMemories().add((Memory) edge); } getEdges().add(edge); } @Override public void add(Vertex vertex) { if (vertex instanceof Processor) { getProcessors().add((Processor) vertex); } else if (vertex instanceof Component) { getComponents().add((Component) vertex); } else { throw new OrccRuntimeException("Unsupported operation"); } getVertices().add(vertex); } @Override public Edge add(Vertex source, Vertex target) { throw new UnsupportedOperationException(); } @Override public void addInput(Port port) { getVertices().add(port); getInputs().add(port); } @Override public void addOutput(Port port) { getVertices().add(port); getOutputs().add(port); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override public Object eGet(int featureID, boolean resolve, boolean coreType) { switch (featureID) { case ArchitecturePackage.DESIGN__NAME: return getName(); case ArchitecturePackage.DESIGN__COMPONENTS: return getComponents(); case ArchitecturePackage.DESIGN__PROCESSORS: return getProcessors(); case ArchitecturePackage.DESIGN__SHARED_MEMORIES: return getSharedMemories(); case ArchitecturePackage.DESIGN__SIGNALS: return getSignals(); case ArchitecturePackage.DESIGN__INPUTS: return getInputs(); case ArchitecturePackage.DESIGN__OUTPUTS: return getOutputs(); case ArchitecturePackage.DESIGN__HARDWARE_DATABASE: if (coreType) return getHardwareDatabase(); else return getHardwareDatabase().map(); } return super.eGet(featureID, resolve, coreType); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case ArchitecturePackage.DESIGN__HARDWARE_DATABASE: return ((InternalEList<?>) getHardwareDatabase()).basicRemove( otherEnd, msgs); } return super.eInverseRemove(otherEnd, featureID, msgs); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case ArchitecturePackage.DESIGN__NAME: return NAME_EDEFAULT == null ? name != null : !NAME_EDEFAULT .equals(name); case ArchitecturePackage.DESIGN__COMPONENTS: return components != null && !components.isEmpty(); case ArchitecturePackage.DESIGN__PROCESSORS: return processors != null && !processors.isEmpty(); case ArchitecturePackage.DESIGN__SHARED_MEMORIES: return sharedMemories != null && !sharedMemories.isEmpty(); case ArchitecturePackage.DESIGN__SIGNALS: return signals != null && !signals.isEmpty(); case ArchitecturePackage.DESIGN__INPUTS: return inputs != null && !inputs.isEmpty(); case ArchitecturePackage.DESIGN__OUTPUTS: return outputs != null && !outputs.isEmpty(); case ArchitecturePackage.DESIGN__HARDWARE_DATABASE: return hardwareDatabase != null && !hardwareDatabase.isEmpty(); } return super.eIsSet(featureID); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @SuppressWarnings("unchecked") @Override public void eSet(int featureID, Object newValue) { switch (featureID) { case ArchitecturePackage.DESIGN__NAME: setName((String) newValue); return; case ArchitecturePackage.DESIGN__COMPONENTS: getComponents().clear(); getComponents().addAll((Collection<? extends Component>) newValue); return; case ArchitecturePackage.DESIGN__PROCESSORS: getProcessors().clear(); getProcessors().addAll((Collection<? extends Processor>) newValue); return; case ArchitecturePackage.DESIGN__SHARED_MEMORIES: getSharedMemories().clear(); getSharedMemories().addAll((Collection<? extends Memory>) newValue); return; case ArchitecturePackage.DESIGN__SIGNALS: getSignals().clear(); getSignals().addAll((Collection<? extends Signal>) newValue); return; case ArchitecturePackage.DESIGN__INPUTS: getInputs().clear(); getInputs().addAll((Collection<? extends Port>) newValue); return; case ArchitecturePackage.DESIGN__OUTPUTS: getOutputs().clear(); getOutputs().addAll((Collection<? extends Port>) newValue); return; case ArchitecturePackage.DESIGN__HARDWARE_DATABASE: ((EStructuralFeature.Setting) getHardwareDatabase()).set(newValue); return; } super.eSet(featureID, newValue); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return ArchitecturePackage.Literals.DESIGN; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case ArchitecturePackage.DESIGN__NAME: setName(NAME_EDEFAULT); return; case ArchitecturePackage.DESIGN__COMPONENTS: getComponents().clear(); return; case ArchitecturePackage.DESIGN__PROCESSORS: getProcessors().clear(); return; case ArchitecturePackage.DESIGN__SHARED_MEMORIES: getSharedMemories().clear(); return; case ArchitecturePackage.DESIGN__SIGNALS: getSignals().clear(); return; case ArchitecturePackage.DESIGN__INPUTS: getInputs().clear(); return; case ArchitecturePackage.DESIGN__OUTPUTS: getOutputs().clear(); return; case ArchitecturePackage.DESIGN__HARDWARE_DATABASE: getHardwareDatabase().clear(); return; } super.eUnset(featureID); } @Override public Map<Vertex, Processor> getActorToProcessorMap() { Map<Vertex, Processor> map = new HashMap<Vertex, Processor>(); for (Processor processor : getProcessors()) { for (Vertex actor : processor.getMappedActors()) { map.put(actor, processor); } } return map; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public EList<Component> getComponents() { if (components == null) { components = new EObjectResolvingEList<Component>(Component.class, this, ArchitecturePackage.DESIGN__COMPONENTS); } return components; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public EMap<String, Implementation> getHardwareDatabase() { if (hardwareDatabase == null) { hardwareDatabase = new EcoreEMap<String, Implementation>( ArchitecturePackage.Literals.TYPE_TO_IMPL_MAP_ENTRY, TypeToImplMapEntryImpl.class, this, ArchitecturePackage.DESIGN__HARDWARE_DATABASE); } return hardwareDatabase; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public EList<Port> getInputs() { if (inputs == null) { inputs = new EObjectResolvingEList<Port>(Port.class, this, ArchitecturePackage.DESIGN__INPUTS); } return inputs; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public String getName() { return name; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public EList<Port> getOutputs() { if (outputs == null) { outputs = new EObjectResolvingEList<Port>(Port.class, this, ArchitecturePackage.DESIGN__OUTPUTS); } return outputs; } @Override public Processor getProcessor(String name) { for (Processor processor : getProcessors()) { if (processor.getName().equals(name)) { return processor; } } return null; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public EList<Processor> getProcessors() { if (processors == null) { processors = new EObjectResolvingEList<Processor>(Processor.class, this, ArchitecturePackage.DESIGN__PROCESSORS); } return processors; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public EList<Memory> getSharedMemories() { if (sharedMemories == null) { sharedMemories = new EObjectResolvingEList<Memory>(Memory.class, this, ArchitecturePackage.DESIGN__SHARED_MEMORIES); } return sharedMemories; } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ public EList<Signal> getSignals() { if (signals == null) { signals = new EObjectResolvingEList<Signal>(Signal.class, this, ArchitecturePackage.DESIGN__SIGNALS); } return signals; } /** * <!-- 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, ArchitecturePackage.DESIGN__NAME, oldName, name)); } /** * <!-- begin-user-doc --> <!-- end-user-doc --> * @generated */ @Override public String toString() { if (eIsProxy()) return super.toString(); StringBuffer result = new StringBuffer(super.toString()); result.append(" (name: "); result.append(name); result.append(')'); return result.toString(); } } // DesignImpl