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