Made LogicUI compatible with ReadEnd and ReadWriteEnd
[Mograsim.git] / LogicUI / src / era / mi / gui / components / GUIManualSwitch.java
index 9d58cac..48662d3 100644 (file)
@@ -2,10 +2,14 @@ package era.mi.gui.components;
 
 import java.util.ArrayList;
 import java.util.Collections;
+import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
 
 import era.mi.logic.components.ManualSwitch;
-import era.mi.logic.wires.WireArray;
+import era.mi.logic.types.Bit;
+import era.mi.logic.wires.Wire.ReadEnd;
+import era.mi.logic.wires.Wire.ReadWriteEnd;
 import net.haspamelodica.swt.helper.gcs.GeneralGC;
 import net.haspamelodica.swt.helper.swtobjectwrappers.Font;
 import net.haspamelodica.swt.helper.swtobjectwrappers.Point;
@@ -13,21 +17,36 @@ import net.haspamelodica.swt.helper.swtobjectwrappers.Rectangle;
 
 public class GUIManualSwitch extends ManualSwitch implements BasicGUIComponent
 {
-       private final List<WireArray>   connectedWireArrays;
-       private final List<Point>               wireArrayConnectionPoints;
+       private static final Map<Bit, String> bitNames;
+       static
+       {
+               Map<Bit, String> bitNamesModifiable = new HashMap<>();
+               bitNamesModifiable.put(Bit.ONE, "1");
+               bitNamesModifiable.put(Bit.ZERO, "0");
+               bitNamesModifiable.put(Bit.Z, "Z");
+               bitNamesModifiable.put(Bit.U, "U");
+               bitNamesModifiable.put(Bit.X, "X");
+               bitNames = Collections.unmodifiableMap(bitNamesModifiable);
+       }
 
-       public GUIManualSwitch(WireArray output)
+       private final ReadEnd we;
+       private final List<ReadEnd> connectedWireEnds;
+       private final List<Point> wireEndConnectionPoints;
+
+       public GUIManualSwitch(ReadWriteEnd output)
        {
                super(output);
 
-               List<WireArray> connectedWireArraysModifiable = new ArrayList<>();
-               List<Point> wireArrayConnectionPointsModifiable = new ArrayList<>();
+               this.we = output;
+
+               List<ReadEnd> connectedWireEndsModifiable = new ArrayList<>();
+               List<Point> wireEndConnectionPointsModifiable = new ArrayList<>();
 
-               connectedWireArraysModifiable.add(output);
-               wireArrayConnectionPointsModifiable.add(new Point(20, 7.5));
+               connectedWireEndsModifiable.add(output);
+               wireEndConnectionPointsModifiable.add(new Point(20, 7.5));
 
-               this.connectedWireArrays = Collections.unmodifiableList(connectedWireArraysModifiable);
-               this.wireArrayConnectionPoints = Collections.unmodifiableList(wireArrayConnectionPointsModifiable);
+               this.connectedWireEnds = Collections.unmodifiableList(connectedWireEndsModifiable);
+               this.wireEndConnectionPoints = Collections.unmodifiableList(wireEndConnectionPointsModifiable);
        }
 
        @Override
@@ -35,11 +54,12 @@ public class GUIManualSwitch extends ManualSwitch implements BasicGUIComponent
        {
                return new Rectangle(0, 0, 20, 15);
        }
+
        @Override
        public void render(GeneralGC gc)
        {
                gc.drawRectangle(0, 0, 20, 15);
-               String label = isOn() ? "ON" : "OFF";
+               String label = bitNames.get(we.getValue());
                Font oldFont = gc.getFont();
                Font labelFont = new Font(oldFont.getName(), 6, oldFont.getStyle());
                gc.setFont(labelFont);
@@ -47,6 +67,7 @@ public class GUIManualSwitch extends ManualSwitch implements BasicGUIComponent
                gc.drawText(label, 10 - textExtent.x / 2, 7.5 - textExtent.y / 2, true);
                gc.setFont(oldFont);
        }
+
        @Override
        public boolean clicked(double x, double y)
        {
@@ -55,18 +76,20 @@ public class GUIManualSwitch extends ManualSwitch implements BasicGUIComponent
        }
 
        @Override
-       public int getConnectedWireArraysCount()
+       public int getConnectedWireEndsCount()
        {
-               return connectedWireArrays.size();
+               return connectedWireEnds.size();
        }
+
        @Override
-       public WireArray getConnectedWireArray(int connectionIndex)
+       public ReadEnd getConnectedWireEnd(int connectionIndex)
        {
-               return connectedWireArrays.get(connectionIndex);
+               return connectedWireEnds.get(connectionIndex);
        }
+
        @Override
-       public Point getWireArrayConnectionPoint(int connectionI)
+       public Point getWireEndConnectionPoint(int connectionI)
        {
-               return wireArrayConnectionPoints.get(connectionI);
+               return wireEndConnectionPoints.get(connectionI);
        }
 }
\ No newline at end of file