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.WireEnd;
12 public class Clock implements TimelineEventHandler, Component
14 private boolean toggle = false;
20 * @param out {@link Wire} the clock's impulses are fed into
21 * @param delta ticks between rising and falling edge
23 public Clock(WireEnd out, int delta)
31 public void handle(TimelineEvent e)
34 out.feedSignals(toggle ? Bit.ONE : Bit.ZERO);
38 public WireEnd getOut()
43 private void addToTimeline()
45 Simulation.TIMELINE.addEvent(this, delta);
49 public List<WireEnd> getAllInputs()
55 public List<WireEnd> getAllOutputs()