The line dash of singlebit wires changes according to their value
[Mograsim.git] / plugins / net.mograsim.logic.model.am2900 / src / net / mograsim / logic / model / examples / ModelComponentTestbench.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.Am2900Loader;
9 import net.mograsim.logic.model.am2900.machine.Am2900ExpertMachineDefinition;
10 import net.mograsim.logic.model.model.LogicModelModifiable;
11 import net.mograsim.logic.model.model.components.ModelComponent;
12 import net.mograsim.logic.model.model.components.atomic.ModelBitDisplay;
13 import net.mograsim.logic.model.model.components.atomic.ModelManualSwitch;
14 import net.mograsim.logic.model.model.components.atomic.ModelTextComponent;
15 import net.mograsim.logic.model.model.wires.ModelWire;
16 import net.mograsim.logic.model.model.wires.Pin;
17 import net.mograsim.logic.model.model.wires.PinUsage;
18
19 public class ModelComponentTestbench
20 {
21         public static void main(String[] args)
22         {
23                 SimpleLogicUIStandalone.executeVisualisation(ModelComponentTestbench::createTestbench);
24         }
25
26         @SuppressWarnings("unused") // for ModelWires being created
27         public static void createTestbench(LogicModelModifiable model)
28         {
29                 Am2900Loader.setup();
30                 ModelComponent comp = new Am2900ExpertMachineDefinition().createNew(model).getAm2900();
31 //              ModelComponent comp = IndirectModelComponentCreator.createComponent(model, "ram5_12");
32
33                 List<String> inputPinNames = new ArrayList<>();
34                 List<String> outputPinNames = new ArrayList<>();
35                 for (Pin p : comp.getPins().values())
36                         if (p.usage == PinUsage.INPUT)
37                                 inputPinNames.add(p.name);
38                         else
39                                 // TODO handle TRISTATE pins
40                                 outputPinNames.add(p.name);
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                         String pinName = inputPinNames.get(i);
49                         ModelManualSwitch sw = new ModelManualSwitch(model, comp.getPin(pinName).logicWidth, pinName);
50                         sw.moveTo(0, 20 * i);
51                         new ModelTextComponent(model, pinName).moveTo(20, 20 * i);
52                         new ModelWire(model, comp.getPin(pinName), sw.getOutputPin());
53                 }
54                 for (int i = 0; i < outputPinNames.size(); i++)
55                 {
56                         String pinName = outputPinNames.get(i);
57                         ModelBitDisplay bd = new ModelBitDisplay(model, comp.getPin(pinName).logicWidth, pinName);
58                         bd.moveTo(200, 20 * i);
59                         new ModelTextComponent(model, pinName).moveTo(220, 20 * i);
60                         new ModelWire(model, comp.getPin(pinName), bd.getInputPin());
61                 }
62         }
63 }