1 package era.mi.logic.tests;
3 import era.mi.logic.Bit;
4 import era.mi.logic.Simulation;
5 import era.mi.logic.wires.WireArray;
6 import era.mi.logic.wires.WireArray.WireArrayInput;
7 import era.mi.logic.wires.WireArrayObserver;
9 public class Connector implements WireArrayObserver
11 private final WireArray a;
12 private final WireArray b;
13 private final WireArrayInput aI;
14 private final WireArrayInput bI;
16 public Connector(WireArray a, WireArray b)
18 if (a.length != b.length)
19 throw new IllegalArgumentException(String.format("WireArray width does not match: %o, %o", a.length, b.length));
29 public void update(WireArray initiator, Bit[] oldValues)
31 Simulation.TIMELINE.addEvent((e) ->
34 bI.feedSignals(aI.wireValuesExcludingMe());
36 aI.feedSignals(bI.wireValuesExcludingMe());