Implemented set/getHighLevelState for most components
[Mograsim.git] / net.mograsim.logic.ui.am2900 / src / net / mograsim / logic / ui / model / components / mi / nandbased / GUIdlatch4.java
index 440cfb4..8da90e1 100644 (file)
@@ -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