X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=net.mograsim.logic.ui.am2900%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fui%2Fmodel%2Fcomponents%2Fmi%2Fnandbased%2FGUIdlatch4.java;h=8da90e16e04b888204d1b2d47ca060df424ca22c;hb=74bced7a3a38f65c65f3395cc422eb98e34da0b8;hp=440cfb40e19bd6a19a21eab2a85ac7097e6a4341;hpb=05e36ce451a394259e3ed21ea21ac3a1fd7d4e40;p=Mograsim.git diff --git a/net.mograsim.logic.ui.am2900/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIdlatch4.java b/net.mograsim.logic.ui.am2900/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIdlatch4.java index 440cfb40..8da90e16 100644 --- a/net.mograsim.logic.ui.am2900/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIdlatch4.java +++ b/net.mograsim.logic.ui.am2900/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIdlatch4.java @@ -1,6 +1,8 @@ package net.mograsim.logic.ui.model.components.mi.nandbased; import net.haspamelodica.swt.helper.swtobjectwrappers.Point; +import net.mograsim.logic.core.types.Bit; +import net.mograsim.logic.core.types.BitVector; import net.mograsim.logic.ui.model.ViewModelModifiable; import net.mograsim.logic.ui.model.components.SimpleRectangularSubmodelComponent; import net.mograsim.logic.ui.model.wires.GUIWire; @@ -9,6 +11,11 @@ import net.mograsim.logic.ui.model.wires.WireCrossPoint; public class GUIdlatch4 extends SimpleRectangularSubmodelComponent { + private GUIdlatch dlatch1; + private GUIdlatch dlatch2; + private GUIdlatch dlatch3; + private GUIdlatch dlatch4; + public GUIdlatch4(ViewModelModifiable model) { super(model, 1, "GUIdlatch4"); @@ -31,10 +38,10 @@ public class GUIdlatch4 extends SimpleRectangularSubmodelComponent Pin Q3 = getSubmodelPin("Q3"); Pin Q4 = getSubmodelPin("Q4"); - GUIdlatch dlatch1 = new GUIdlatch(submodelModifiable); - GUIdlatch dlatch2 = new GUIdlatch(submodelModifiable); - GUIdlatch dlatch3 = new GUIdlatch(submodelModifiable); - GUIdlatch dlatch4 = new GUIdlatch(submodelModifiable); + dlatch1 = new GUIdlatch(submodelModifiable); + dlatch2 = new GUIdlatch(submodelModifiable); + dlatch3 = new GUIdlatch(submodelModifiable); + dlatch4 = new GUIdlatch(submodelModifiable); WireCrossPoint cp2 = new WireCrossPoint(submodelModifiable, 1); WireCrossPoint cp3 = new WireCrossPoint(submodelModifiable, 1); @@ -64,4 +71,58 @@ public class GUIdlatch4 extends SimpleRectangularSubmodelComponent new GUIWire(submodelModifiable, dlatch3.getPin("Q"), Q3, new Point[0]); new GUIWire(submodelModifiable, dlatch4.getPin("Q"), Q4, new Point[0]); } + + @Override + public void setHighLevelState(String stateID, Object newState) + { + switch (stateID) + { + case "q1": + dlatch1.setHighLevelState("q", newState); + break; + case "q2": + dlatch2.setHighLevelState("q", newState); + break; + case "q3": + dlatch3.setHighLevelState("q", newState); + break; + case "q4": + dlatch4.setHighLevelState("q", newState); + break; + case "q": + BitVector newStateCasted = (BitVector) newState; + setHighLevelState("q1", newStateCasted.getBit(0)); + setHighLevelState("q2", newStateCasted.getBit(1)); + setHighLevelState("q3", newStateCasted.getBit(2)); + setHighLevelState("q4", newStateCasted.getBit(3)); + break; + default: + super.setHighLevelState(stateID, newState); + break; + } + } + + @Override + public Object getHighLevelState(String stateID) + { + switch (stateID) + { + case "q1": + return dlatch1.getHighLevelState("q"); + case "q2": + return dlatch2.getHighLevelState("q"); + case "q3": + return dlatch3.getHighLevelState("q"); + case "q4": + return dlatch4.getHighLevelState("q"); + case "q": + Bit q1 = (Bit) getHighLevelState("q1"); + Bit q2 = (Bit) getHighLevelState("q2"); + Bit q3 = (Bit) getHighLevelState("q3"); + Bit q4 = (Bit) getHighLevelState("q4"); + return BitVector.of(q1, q2, q3, q4); + default: + return super.getHighLevelState(stateID); + } + } } \ No newline at end of file