Merge branch 'development' into fusebug
[Mograsim.git] / net.mograsim.logic.model / src / net / mograsim / logic / model / modeladapter / componentadapters / TriStateBufferAdapter.java
1 package net.mograsim.logic.model.modeladapter.componentadapters;
2
3 import java.util.Map;
4
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;
14
15 public class TriStateBufferAdapter implements ComponentAdapter<GUITriStateBuffer>
16 {
17         @Override
18         public Class<GUITriStateBuffer> getSupportedClass()
19         {
20                 return GUITriStateBuffer.class;
21         }
22
23         @SuppressWarnings("unused")
24         @Override
25         public void createAndLinkComponent(Timeline timeline, LogicModelParameters params, GUITriStateBuffer guiTsb,
26                         Map<Pin, Wire> logicWiresPerPin)
27         {
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 ->
35                 {
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());
40                 };
41                 in.registerObserver(obs);
42                 enable.registerObserver(obs);
43                 out.registerObserver(obs);
44         }
45 }