1 package era.mi.logic.components;
5 import era.mi.logic.Simulation;
6 import era.mi.logic.timeline.TimelineEvent;
7 import era.mi.logic.timeline.TimelineEventHandler;
8 import era.mi.logic.types.Bit;
9 import era.mi.logic.wires.Wire;
10 import era.mi.logic.wires.Wire.ReadEnd;
11 import era.mi.logic.wires.Wire.ReadWriteEnd;
13 public class Clock implements TimelineEventHandler, Component
15 private boolean toggle = false;
16 private ReadWriteEnd out;
21 * @param out {@link Wire} the clock's impulses are fed into
22 * @param delta ticks between rising and falling edge
24 public Clock(ReadWriteEnd out, int delta)
32 public void handle(TimelineEvent e)
35 out.feedSignals(toggle ? Bit.ONE : Bit.ZERO);
39 public ReadWriteEnd getOut()
44 private void addToTimeline()
46 Simulation.TIMELINE.addEvent(this, delta);
50 public List<ReadEnd> getAllInputs()
56 public List<ReadWriteEnd> getAllOutputs()