Changed high level addressing to have the correct bit and reg. order
[Mograsim.git] / net.mograsim.logic.ui.am2900 / src / net / mograsim / logic / ui / model / components / mi / nandbased / GUIdlatch4.java
1 package net.mograsim.logic.ui.model.components.mi.nandbased;
2
3 import net.haspamelodica.swt.helper.swtobjectwrappers.Point;
4 import net.mograsim.logic.core.types.Bit;
5 import net.mograsim.logic.core.types.BitVector;
6 import net.mograsim.logic.ui.model.ViewModelModifiable;
7 import net.mograsim.logic.ui.model.components.SimpleRectangularSubmodelComponent;
8 import net.mograsim.logic.ui.model.wires.GUIWire;
9 import net.mograsim.logic.ui.model.wires.Pin;
10 import net.mograsim.logic.ui.model.wires.WireCrossPoint;
11
12 public class GUIdlatch4 extends SimpleRectangularSubmodelComponent
13 {
14         private GUIdlatch dlatch1;
15         private GUIdlatch dlatch2;
16         private GUIdlatch dlatch3;
17         private GUIdlatch dlatch4;
18
19         public GUIdlatch4(ViewModelModifiable model)
20         {
21                 super(model, 1, "GUIdlatch4");
22                 setSubmodelScale(.4);
23                 setInputPins("D1", "D2", "D3", "D4", "C");
24                 setOutputPins("Q1", "Q2", "Q3", "Q4");
25                 initSubmodelComponents();
26         }
27
28         @SuppressWarnings("unused") // for GUIWires being created
29         private void initSubmodelComponents()
30         {
31                 Pin D1 = getSubmodelPin("D1");
32                 Pin D2 = getSubmodelPin("D2");
33                 Pin D3 = getSubmodelPin("D3");
34                 Pin D4 = getSubmodelPin("D4");
35                 Pin C = getSubmodelPin("C");
36                 Pin Q1 = getSubmodelPin("Q1");
37                 Pin Q2 = getSubmodelPin("Q2");
38                 Pin Q3 = getSubmodelPin("Q3");
39                 Pin Q4 = getSubmodelPin("Q4");
40
41                 dlatch1 = new GUIdlatch(submodelModifiable);
42                 dlatch2 = new GUIdlatch(submodelModifiable);
43                 dlatch3 = new GUIdlatch(submodelModifiable);
44                 dlatch4 = new GUIdlatch(submodelModifiable);
45
46                 WireCrossPoint cp2 = new WireCrossPoint(submodelModifiable, 1);
47                 WireCrossPoint cp3 = new WireCrossPoint(submodelModifiable, 1);
48                 WireCrossPoint cp4 = new WireCrossPoint(submodelModifiable, 1);
49
50                 dlatch1.moveTo(30, 7.5);
51                 dlatch2.moveTo(30, 32.5);
52                 dlatch3.moveTo(30, 57.5);
53                 dlatch4.moveTo(30, 82.5);
54                 cp2.moveCenterTo(15, 47.5);
55                 cp3.moveCenterTo(15, 72.5);
56                 cp4.moveCenterTo(15, 97.5);
57
58                 new GUIWire(submodelModifiable, C, cp4, new Point(15, 112.5));
59                 new GUIWire(submodelModifiable, cp4, dlatch4.getPin("E"), new Point[0]);
60                 new GUIWire(submodelModifiable, cp4, cp3, new Point[0]);
61                 new GUIWire(submodelModifiable, cp3, dlatch3.getPin("E"), new Point[0]);
62                 new GUIWire(submodelModifiable, cp3, cp2, new Point[0]);
63                 new GUIWire(submodelModifiable, cp2, dlatch2.getPin("E"), new Point[0]);
64                 new GUIWire(submodelModifiable, cp2, dlatch1.getPin("E"), new Point(15, 22.5));
65                 new GUIWire(submodelModifiable, D1, dlatch1.getPin("D"), new Point[0]);
66                 new GUIWire(submodelModifiable, D2, dlatch2.getPin("D"), new Point[0]);
67                 new GUIWire(submodelModifiable, D3, dlatch3.getPin("D"), new Point[0]);
68                 new GUIWire(submodelModifiable, D4, dlatch4.getPin("D"), new Point[0]);
69                 new GUIWire(submodelModifiable, dlatch1.getPin("Q"), Q1, new Point[0]);
70                 new GUIWire(submodelModifiable, dlatch2.getPin("Q"), Q2, new Point[0]);
71                 new GUIWire(submodelModifiable, dlatch3.getPin("Q"), Q3, new Point[0]);
72                 new GUIWire(submodelModifiable, dlatch4.getPin("Q"), Q4, new Point[0]);
73         }
74
75         @Override
76         public void setHighLevelState(String stateID, Object newState)
77         {
78                 switch (stateID)
79                 {
80                 case "q1":
81                         dlatch1.setHighLevelState("q", newState);
82                         break;
83                 case "q2":
84                         dlatch2.setHighLevelState("q", newState);
85                         break;
86                 case "q3":
87                         dlatch3.setHighLevelState("q", newState);
88                         break;
89                 case "q4":
90                         dlatch4.setHighLevelState("q", newState);
91                         break;
92                 case "q":
93                         BitVector newStateCasted = (BitVector) newState;
94                         setHighLevelState("q1", newStateCasted.getBit(3));
95                         setHighLevelState("q2", newStateCasted.getBit(2));
96                         setHighLevelState("q3", newStateCasted.getBit(1));
97                         setHighLevelState("q4", newStateCasted.getBit(0));
98                         break;
99                 default:
100                         super.setHighLevelState(stateID, newState);
101                         break;
102                 }
103         }
104
105         @Override
106         public Object getHighLevelState(String stateID)
107         {
108                 switch (stateID)
109                 {
110                 case "q1":
111                         return dlatch1.getHighLevelState("q");
112                 case "q2":
113                         return dlatch2.getHighLevelState("q");
114                 case "q3":
115                         return dlatch3.getHighLevelState("q");
116                 case "q4":
117                         return dlatch4.getHighLevelState("q");
118                 case "q":
119                         Bit q1 = (Bit) getHighLevelState("q1");
120                         Bit q2 = (Bit) getHighLevelState("q2");
121                         Bit q3 = (Bit) getHighLevelState("q3");
122                         Bit q4 = (Bit) getHighLevelState("q4");
123                         return BitVector.of(q4, q3, q2, q1);
124                 default:
125                         return super.getHighLevelState(stateID);
126                 }
127         }
128 }