1 package net.mograsim.logic.model.modeladapter.componentadapters;
5 import net.mograsim.logic.core.components.memory.WordAddressableMemoryComponent;
6 import net.mograsim.logic.core.timeline.Timeline;
7 import net.mograsim.logic.core.wires.Wire;
8 import net.mograsim.logic.core.wires.Wire.ReadEnd;
9 import net.mograsim.logic.core.wires.Wire.ReadWriteEnd;
10 import net.mograsim.logic.model.model.components.atomic.GUIMemoryWA;
11 import net.mograsim.logic.model.model.wires.Pin;
12 import net.mograsim.logic.model.modeladapter.LogicModelParameters;
14 public class WordAddressableMemoryAdapter implements ComponentAdapter<GUIMemoryWA>
18 public Class<GUIMemoryWA> getSupportedClass()
20 return GUIMemoryWA.class;
23 @SuppressWarnings("unused")
25 public void createAndLinkComponent(Timeline timeline, LogicModelParameters params, GUIMemoryWA guiComponent,
26 Map<Pin, Wire> logicWiresPerPin)
28 ReadWriteEnd data = logicWiresPerPin.get(guiComponent.getDataPin()).createReadWriteEnd();
29 ReadEnd address = logicWiresPerPin.get(guiComponent.getAddressPin()).createReadOnlyEnd();
30 ReadEnd mode = logicWiresPerPin.get(guiComponent.getReadWritePin()).createReadOnlyEnd();
31 new WordAddressableMemoryComponent(timeline, 2, guiComponent.maximalAddress, guiComponent.minimalAddress, data, mode, address);