X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=net.mograsim.logic.core%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fcore%2Fcomponents%2FConnector.java;fp=net.mograsim.logic.core%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fcore%2Fcomponents%2FConnector.java;h=0000000000000000000000000000000000000000;hb=4db274c53e53cda8321067eca57d524f188c2e6f;hp=528852ed3b287812903dbaccaad7566e6fb8324a;hpb=0ab3dafe756a69ff8b1e0137058caf2f5ac564aa;p=Mograsim.git diff --git a/net.mograsim.logic.core/src/net/mograsim/logic/core/components/Connector.java b/net.mograsim.logic.core/src/net/mograsim/logic/core/components/Connector.java deleted file mode 100644 index 528852ed..00000000 --- a/net.mograsim.logic.core/src/net/mograsim/logic/core/components/Connector.java +++ /dev/null @@ -1,76 +0,0 @@ -package net.mograsim.logic.core.components; - -import java.util.List; - -import net.mograsim.logic.core.LogicObservable; -import net.mograsim.logic.core.LogicObserver; -import net.mograsim.logic.core.timeline.Timeline; -import net.mograsim.logic.core.wires.Wire.ReadEnd; -import net.mograsim.logic.core.wires.Wire.ReadWriteEnd; - -public class Connector extends Component implements LogicObserver -{ - private boolean connected; - private final ReadWriteEnd a; - private final ReadWriteEnd b; - - public Connector(Timeline timeline, ReadWriteEnd a, ReadWriteEnd b) - { - super(timeline); - if (a.width() != b.width()) - throw new IllegalArgumentException(String.format("WireArray width does not match: %d, %d", a.width(), b.width())); - this.a = a; - this.b = b; - a.registerObserver(this); - b.registerObserver(this); - } - - public void connect() - { - connected = true; - update(a); - update(b); - } - - public void disconnect() - { - connected = false; - a.clearSignals(); - b.clearSignals(); - } - - public void setConnection(boolean connected) - { - if (connected) - connect(); - else - disconnect(); - } - - @Override - public void update(LogicObservable initiator) - { - if (connected) - timeline.addEvent(e -> innerUpdate(initiator), 1); - } - - private void innerUpdate(LogicObservable initiator) - { - if (initiator == a) - b.feedSignals(a.wireValuesExcludingMe()); - else - a.feedSignals(b.wireValuesExcludingMe()); - } - - @Override - public List getAllInputs() - { - return List.of(a, b); - } - - @Override - public List getAllOutputs() - { - return List.of(a, b); - } -}