Timeline now passed via constructor
[Mograsim.git] / LogicUI / src / era / mi / gui / components / GUISplitter.java
index 8d09cc7..6873e63 100644 (file)
@@ -6,40 +6,42 @@ import java.util.Collections;
 import java.util.List;
 
 import era.mi.logic.components.Splitter;
-import era.mi.logic.wires.WireArray;
+import era.mi.logic.timeline.Timeline;
+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.Point;
 import net.haspamelodica.swt.helper.swtobjectwrappers.Rectangle;
 
 public class GUISplitter extends Splitter implements BasicGUIComponent
 {
-       private final int                               outputCount;
-       private final double                    height;
-       private final List<WireArray>   connectedWireArrays;
-       private final List<Point>               wireArrayConnectionPoints;
+       private final int outputCount;
+       private final double height;
+       private final List<ReadEnd> connectedWireEnds;
+       private final List<Point> WireEndConnectionPoints;
 
-       public GUISplitter(WireArray input, WireArray... outputs)
+       public GUISplitter(Timeline timeline, ReadEnd input, ReadWriteEnd... outputs)
        {
-               super(input, outputs);
+               super(timeline, input, outputs);
 
-               List<WireArray> connectedWireArraysModifiable = new ArrayList<>();
-               List<Point> wireArrayConnectionPointsModifiable = new ArrayList<>();
+               List<ReadEnd> connectedWireEndsModifiable = new ArrayList<>();
+               List<Point> WireEndConnectionPointsModifiable = new ArrayList<>();
 
                this.outputCount = outputs.length;
                this.height = (outputCount - 1) * 10;
 
-               connectedWireArraysModifiable.add(input);
-               wireArrayConnectionPointsModifiable.add(new Point(0, height / 2));
+               connectedWireEndsModifiable.add(input);
+               WireEndConnectionPointsModifiable.add(new Point(0, height / 2));
 
                {
-                       connectedWireArraysModifiable.addAll(Arrays.asList(outputs));
+                       connectedWireEndsModifiable.addAll(Arrays.asList(outputs));
                        double outputHeight = 0;
-                       for(int i = 0; i < outputCount; i ++, outputHeight += 10)
-                               wireArrayConnectionPointsModifiable.add(new Point(20, outputHeight));
+                       for (int i = 0; i < outputCount; i++, outputHeight += 10)
+                               WireEndConnectionPointsModifiable.add(new Point(20, outputHeight));
                }
 
-               this.connectedWireArrays = Collections.unmodifiableList(connectedWireArraysModifiable);
-               this.wireArrayConnectionPoints = Collections.unmodifiableList(wireArrayConnectionPointsModifiable);
+               this.connectedWireEnds = Collections.unmodifiableList(connectedWireEndsModifiable);
+               this.WireEndConnectionPoints = Collections.unmodifiableList(WireEndConnectionPointsModifiable);
        }
 
        @Override
@@ -47,29 +49,32 @@ public class GUISplitter extends Splitter implements BasicGUIComponent
        {
                return new Rectangle(0, 0, 20, height);
        }
+
        @Override
        public void render(GeneralGC gc)
        {
                gc.drawLine(0, height / 2, 10, height / 2);
                gc.drawLine(10, 0, 10, height);
                double outputHeight = 0;
-               for(int i = 0; i < outputCount; i ++, outputHeight += 10)
+               for (int i = 0; i < outputCount; i++, outputHeight += 10)
                        gc.drawLine(10, outputHeight, 20, outputHeight);
        }
 
        @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