Did some clean up
[Mograsim.git] / era.mi / src / era / mi / logic / components / Clock.java
index 8e966f1..2809027 100644 (file)
@@ -1,7 +1,5 @@
 package era.mi.logic.components;\r
 \r
-import java.util.Arrays;\r
-import java.util.Collections;\r
 import java.util.List;\r
 \r
 import era.mi.logic.Bit;\r
@@ -9,11 +7,12 @@ import era.mi.logic.Simulation;
 import era.mi.logic.timeline.TimelineEvent;\r
 import era.mi.logic.timeline.TimelineEventHandler;\r
 import era.mi.logic.wires.WireArray;\r
-import era.mi.logic.wires.WireArray.WireArrayInput;\r
+import era.mi.logic.wires.WireArray.WireArrayEnd;\r
 \r
-public class Clock implements TimelineEventHandler, Component {\r
+public class Clock implements TimelineEventHandler, Component\r
+{\r
        private boolean toggle = false;\r
-       private WireArrayInput outI;\r
+       private WireArrayEnd outI;\r
        private int delta;\r
 \r
        /**\r
@@ -21,34 +20,40 @@ public class Clock implements TimelineEventHandler, Component {
         * @param out   {@link WireArray} the clock's impulses are fed into\r
         * @param delta ticks between rising and falling edge\r
         */\r
-       public Clock(WireArray out, int delta) {\r
+       public Clock(WireArray out, int delta)\r
+       {\r
                this.delta = delta;\r
                this.outI = out.createInput();\r
-               Simulation.TIMELINE.addEvent(this, 50);\r
+               Simulation.TIMELINE.addEvent(this, delta);\r
        }\r
 \r
        @Override\r
-       public void handle(TimelineEvent e) {\r
+       public void handle(TimelineEvent e)\r
+       {\r
                addToTimeline();\r
-               outI.feedSignals(new Bit[] { toggle ? Bit.ONE : Bit.ZERO });\r
+               outI.feedSignals(toggle ? Bit.ONE : Bit.ZERO);\r
                toggle = !toggle;\r
        }\r
 \r
-       public WireArray getOut() {\r
+       public WireArray getOut()\r
+       {\r
                return outI.owner;\r
        }\r
 \r
-       private void addToTimeline() {\r
+       private void addToTimeline()\r
+       {\r
                Simulation.TIMELINE.addEvent(this, delta);\r
        }\r
 \r
        @Override\r
-       public List<WireArray> getAllInputs() {\r
-               return Collections.unmodifiableList(Arrays.asList());\r
+       public List<WireArray> getAllInputs()\r
+       {\r
+               return List.of();\r
        }\r
 \r
        @Override\r
-       public List<WireArray> getAllOutputs() {\r
-               return Collections.unmodifiableList(Arrays.asList(outI.owner));\r
+       public List<WireArray> getAllOutputs()\r
+       {\r
+               return List.of(outI.owner);\r
        }\r
 }\r