f63e17981593258f5dc2cb5f1622d4bf6ef69ff7
[Mograsim.git] / net.mograsim.logic.ui / src / net / mograsim / logic / ui / examples / SubmodelComponentTestbench.java
1 package net.mograsim.logic.ui.examples;
2
3 import net.mograsim.logic.ui.SimpleLogicUIStandalone;
4 import net.mograsim.logic.ui.model.ViewModelModifiable;
5 import net.mograsim.logic.ui.model.components.GUIBitDisplay;
6 import net.mograsim.logic.ui.model.components.GUIManualSwitch;
7 import net.mograsim.logic.ui.model.components.SubmodelComponent;
8 import net.mograsim.logic.ui.model.components.mi.nandbased.GUIdlatch;
9 import net.mograsim.logic.ui.model.wires.GUIWire;
10
11 public class SubmodelComponentTestbench
12 {
13         public static void main(String[] args)
14         {
15                 SimpleLogicUIStandalone.executeVisualisation(SubmodelComponentTestbench::createTestbench);
16         }
17
18         @SuppressWarnings("unused") // for GUIWires being created
19         public static void createTestbench(ViewModelModifiable model)
20         {
21                 SubmodelComponent comp = new GUIdlatch(model);
22                 int inputCount = 2;
23
24                 comp.moveTo(100, 0);
25                 for (int i = 0; i < inputCount; i++)
26                 {
27                         GUIManualSwitch sw = new GUIManualSwitch(model);
28                         sw.moveTo(0, 20 * i);
29                         new GUIWire(model, comp.getPins().get(i), sw.getOutputPin());
30                 }
31                 for (int i = inputCount; i < comp.getPins().size(); i++)
32                 {
33                         GUIBitDisplay bd = new GUIBitDisplay(model);
34                         bd.moveTo(200, 20 * (i - inputCount));
35                         new GUIWire(model, comp.getPins().get(i), bd.getInputPin());
36                 }
37         }
38 }