X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=LogicUI%2Fsrc%2Fera%2Fmi%2Fgui%2Fmodel%2Fwires%2FGUIWire.java;h=6bcbd1c594f9b4ff8f65f90e2db9f02a307bac21;hb=ff64c7030e7b7b93cbe974eaf788444063e1aa72;hp=c2f03ee56d3e3430ede18856d0eb952ad687448b;hpb=e618fa725540dd5f92ccf0ed7d65acdc8eb83f93;p=Mograsim.git diff --git a/LogicUI/src/era/mi/gui/model/wires/GUIWire.java b/LogicUI/src/era/mi/gui/model/wires/GUIWire.java index c2f03ee5..6bcbd1c5 100644 --- a/LogicUI/src/era/mi/gui/model/wires/GUIWire.java +++ b/LogicUI/src/era/mi/gui/model/wires/GUIWire.java @@ -14,17 +14,21 @@ import net.haspamelodica.swt.helper.swtobjectwrappers.Point; public class GUIWire { private final ViewModel model; + public final int logicWidth; private Pin pin1; private Pin pin2; private double[] path; - private final List> wireChangedListeners; + private final List> wireLookChangedListeners; private ReadEnd end; public GUIWire(ViewModel model, Pin pin1, Pin pin2, Point... path) { this.model = model; + this.logicWidth = pin1.logicWidth; + if (pin2.logicWidth != pin1.logicWidth) + throw new IllegalArgumentException("Can't connect pins of different logic width"); this.path = new double[path.length * 2 + 4]; for (int srcI = 0, dstI = 2; srcI < path.length; srcI++, dstI += 2) { @@ -35,7 +39,7 @@ public class GUIWire this.pin1 = pin1; this.pin2 = pin2; - wireChangedListeners = new ArrayList<>(); + wireLookChangedListeners = new ArrayList<>(); pin1.addPinMovedListener(p -> pin1Moved()); pin2.addPinMovedListener(p -> pin2Moved()); @@ -72,15 +76,25 @@ public class GUIWire public void setLogicModelBinding(ReadEnd end) { this.end = end; - end.addObserver((i, o) -> callWireChangedListeners()); + end.addObserver((i, o) -> callWireLookChangedListeners()); + } + + public Pin getPin1() + { + return pin1; + } + + public Pin getPin2() + { + return pin2; } // @formatter:off - public void addWireChangedListener (Consumer listener) {wireChangedListeners.add (listener);} + public void addWireLookChangedListener (Consumer listener) {wireLookChangedListeners.add (listener);} - public void removeWireChangedListener(Consumer listener) {wireChangedListeners.remove(listener);} + public void removeWireLookChangedListener(Consumer listener) {wireLookChangedListeners.remove(listener);} - private void callWireChangedListeners() {wireChangedListeners.forEach(l -> l.accept(this));} + private void callWireLookChangedListeners() {wireLookChangedListeners.forEach(l -> l.accept(this));} // @formatter:on } \ No newline at end of file