Implemented GUIAm2910RegCntr
[Mograsim.git] / net.mograsim.logic.model.am2900 / src / net / mograsim / logic / model / examples / GUIComponentTestbench.java
index 362524b..b57522d 100644 (file)
@@ -5,13 +5,15 @@ import java.util.Comparator;
 import java.util.List;
 
 import net.mograsim.logic.model.SimpleLogicUIStandalone;
+import net.mograsim.logic.model.am2900.components.am2910.GUIAm2910RegCntr;
 import net.mograsim.logic.model.model.ViewModelModifiable;
 import net.mograsim.logic.model.model.components.GUIComponent;
 import net.mograsim.logic.model.model.components.atomic.GUIBitDisplay;
 import net.mograsim.logic.model.model.components.atomic.GUIManualSwitch;
+import net.mograsim.logic.model.model.components.atomic.SimpleRectangularHardcodedGUIComponent;
+import net.mograsim.logic.model.model.components.atomic.SimpleRectangularHardcodedGUIComponent.Usage;
 import net.mograsim.logic.model.model.wires.GUIWire;
 import net.mograsim.logic.model.model.wires.Pin;
-import net.mograsim.logic.model.serializing.IndirectGUIComponentCreator;
 
 public class GUIComponentTestbench
 {
@@ -23,17 +25,27 @@ public class GUIComponentTestbench
        @SuppressWarnings("unused") // for GUIWires being created
        public static void createTestbench(ViewModelModifiable model)
        {
-               GUIComponent comp = IndirectGUIComponentCreator.createComponent(model, "GUIAm2901", "Am2901");
+//             GUIComponent comp = IndirectGUIComponentCreator.createComponent(model, "GUIAm2901", "Am2901");
+               GUIComponent comp = new GUIAm2910RegCntr(model, "RegCntr");
 
                // guess which pins are outputs and which are inputs
                // TODO this code exists four times... but it seems too "hacky" to put it in a helper class
                List<String> inputPinNames = new ArrayList<>();
                List<String> outputPinNames = new ArrayList<>();
-               for (Pin p : comp.getPins().values())
-                       if (p.getRelX() == 0)
-                               inputPinNames.add(p.name);
-                       else
-                               outputPinNames.add(p.name);
+               if (comp instanceof SimpleRectangularHardcodedGUIComponent)
+               {
+                       SimpleRectangularHardcodedGUIComponent compCasted = (SimpleRectangularHardcodedGUIComponent) comp;
+                       for (Pin p : comp.getPins().values())
+                               if (compCasted.getPinUsage(p) == Usage.INPUT)
+                                       inputPinNames.add(p.name);
+                               else
+                                       outputPinNames.add(p.name);
+               } else
+                       for (Pin p : comp.getPins().values())
+                               if (p.getRelX() == 0)
+                                       inputPinNames.add(p.name);
+                               else
+                                       outputPinNames.add(p.name);
 
                inputPinNames.sort(Comparator.comparing(comp::getPin, Comparator.comparing(Pin::getRelY)));
                outputPinNames.sort(Comparator.comparing(comp::getPin, Comparator.comparing(Pin::getRelY)));
@@ -41,15 +53,23 @@ public class GUIComponentTestbench
                comp.moveTo(100, 0);
                for (int i = 0; i < inputPinNames.size(); i++)
                {
-                       GUIManualSwitch sw = new GUIManualSwitch(model);
-                       sw.moveTo(0, 20 * i);
-                       new GUIWire(model, comp.getPin(inputPinNames.get(i)), sw.getOutputPin());
+                       String pinName = inputPinNames.get(i);
+                       if (comp.getPin(pinName).logicWidth == 1)
+                       {
+                               GUIManualSwitch sw = new GUIManualSwitch(model);
+                               sw.moveTo(0, 20 * i);
+                               new GUIWire(model, comp.getPin(pinName), sw.getOutputPin());
+                       }
                }
                for (int i = 0; i < outputPinNames.size(); i++)
                {
-                       GUIBitDisplay bd = new GUIBitDisplay(model);
-                       bd.moveTo(200, 20 * i);
-                       new GUIWire(model, comp.getPin(outputPinNames.get(i)), bd.getInputPin());
+                       String pinName = outputPinNames.get(i);
+                       if (comp.getPin(pinName).logicWidth == 1)
+                       {
+                               GUIBitDisplay bd = new GUIBitDisplay(model);
+                               bd.moveTo(200, 20 * i);
+                               new GUIWire(model, comp.getPin(pinName), bd.getInputPin());
+                       }
                }
        }
 }
\ No newline at end of file