1 package net.mograsim.logic.model.modeladapter.componentadapters;
5 import net.mograsim.logic.core.LogicObserver;
6 import net.mograsim.logic.core.components.TriStateBuffer;
7 import net.mograsim.logic.core.timeline.Timeline;
8 import net.mograsim.logic.core.wires.Wire;
9 import net.mograsim.logic.core.wires.Wire.ReadEnd;
10 import net.mograsim.logic.core.wires.Wire.ReadWriteEnd;
11 import net.mograsim.logic.model.model.components.atomic.GUITriStateBuffer;
12 import net.mograsim.logic.model.model.wires.Pin;
13 import net.mograsim.logic.model.modeladapter.LogicModelParameters;
15 public class TriStateBufferAdapter implements ComponentAdapter<GUITriStateBuffer>
18 public Class<GUITriStateBuffer> getSupportedClass()
20 return GUITriStateBuffer.class;
23 @SuppressWarnings("unused")
25 public void createAndLinkComponent(Timeline timeline, LogicModelParameters params, GUITriStateBuffer guiTsb,
26 Map<Pin, Wire> logicWiresPerPin)
28 ReadEnd in = logicWiresPerPin.get(guiTsb.getPin("IN")).createReadOnlyEnd();
29 ReadEnd enable = logicWiresPerPin.get(guiTsb.getPin("EN")).createReadOnlyEnd();
30 ReadWriteEnd out = logicWiresPerPin.get(guiTsb.getPin("OUT")).createReadWriteEnd();
31 new TriStateBuffer(timeline, params.gateProcessTime, in, out, enable);
32 // TODO debug code below - remove
33 String msgHeader = '<' + guiTsb.name + ">: ";
34 LogicObserver obs = c ->
36 System.out.println(msgHeader + "wire states:");
37 System.out.println(msgHeader + " in : " + in.getValues());
38 System.out.println(msgHeader + " enable: " + enable.getValues());
39 System.out.println(msgHeader + " out : " + out.getValues());
41 in.registerObserver(obs);
42 enable.registerObserver(obs);
43 out.registerObserver(obs);