Implemented Am2910's Instruction PLA
[Mograsim.git] / net.mograsim.logic.model.am2900 / src / net / mograsim / logic / model / examples / GUIComponentTestbench.java
1 package net.mograsim.logic.model.examples;
2
3 import java.util.ArrayList;
4 import java.util.Comparator;
5 import java.util.List;
6
7 import net.mograsim.logic.model.SimpleLogicUIStandalone;
8 import net.mograsim.logic.model.am2900.components.am2910.GUIAm2910InstrPLA;
9 import net.mograsim.logic.model.model.ViewModelModifiable;
10 import net.mograsim.logic.model.model.components.GUIComponent;
11 import net.mograsim.logic.model.model.components.atomic.GUIBitDisplay;
12 import net.mograsim.logic.model.model.components.atomic.GUIManualSwitch;
13 import net.mograsim.logic.model.model.wires.GUIWire;
14 import net.mograsim.logic.model.model.wires.Pin;
15
16 public class GUIComponentTestbench
17 {
18         public static void main(String[] args)
19         {
20                 SimpleLogicUIStandalone.executeVisualisation(GUIComponentTestbench::createTestbench);
21         }
22
23         @SuppressWarnings("unused") // for GUIWires being created
24         public static void createTestbench(ViewModelModifiable model)
25         {
26 //              GUIComponent comp = IndirectGUIComponentCreator.createComponent(model, "GUIAm2901", "Am2901");
27                 GUIComponent comp = new GUIAm2910InstrPLA(model, "Am2910");
28
29                 // guess which pins are outputs and which are inputs
30                 // TODO this code exists four times... but it seems too "hacky" to put it in a helper class
31                 List<String> inputPinNames = new ArrayList<>();
32                 List<String> outputPinNames = new ArrayList<>();
33                 for (Pin p : comp.getPins().values())
34                         if (p.getRelX() == 0)
35                                 inputPinNames.add(p.name);
36                         else
37                                 outputPinNames.add(p.name);
38
39                 outputPinNames.remove("R=0");
40                 inputPinNames.add("R=0");
41
42                 inputPinNames.sort(Comparator.comparing(comp::getPin, Comparator.comparing(Pin::getRelY)));
43                 outputPinNames.sort(Comparator.comparing(comp::getPin, Comparator.comparing(Pin::getRelY)));
44
45                 comp.moveTo(100, 0);
46                 for (int i = 0; i < inputPinNames.size(); i++)
47                 {
48                         GUIManualSwitch sw = new GUIManualSwitch(model);
49                         sw.moveTo(0, 20 * i);
50                         new GUIWire(model, comp.getPin(inputPinNames.get(i)), sw.getOutputPin());
51                 }
52                 for (int i = 0; i < outputPinNames.size(); i++)
53                 {
54                         GUIBitDisplay bd = new GUIBitDisplay(model);
55                         bd.moveTo(200, 20 * i);
56                         new GUIWire(model, comp.getPin(outputPinNames.get(i)), bd.getInputPin());
57                 }
58         }
59 }