9902b24a5c7a8c95c2cd1d2794654d5ec4f4de7c
[Mograsim.git] / net.mograsim.logic.model.am2900 / src / net / mograsim / logic / model / model / components / mi / nandbased / am2901 / GUIAm2901QReg.java
1 package net.mograsim.logic.model.model.components.mi.nandbased.am2901;
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.model.model.ViewModelModifiable;
7 import net.mograsim.logic.model.model.components.mi.nandbased.GUIand;
8 import net.mograsim.logic.model.model.components.mi.nandbased.GUIdff;
9 import net.mograsim.logic.model.model.components.submodels.SimpleRectangularSubmodelComponent;
10 import net.mograsim.logic.model.model.wires.GUIWire;
11 import net.mograsim.logic.model.model.wires.Pin;
12 import net.mograsim.logic.model.model.wires.WireCrossPoint;
13 import net.mograsim.logic.model.serializing.IndirectGUIComponentCreator;
14
15 public class GUIAm2901QReg extends SimpleRectangularSubmodelComponent
16 {
17         private GUIdff dff1;
18         private GUIdff dff2;
19         private GUIdff dff3;
20         private GUIdff dff4;
21
22         public GUIAm2901QReg(ViewModelModifiable model)
23         {
24                 this(model, null);
25         }
26
27         public GUIAm2901QReg(ViewModelModifiable model, String name)
28         {
29                 super(model, 1, "GUIAm2901QReg", name);
30                 setSubmodelScale(.4);
31                 setInputPins("C", "WE", "D1", "D2", "D3", "D4");
32                 setOutputPins("Q1", "Q2", "Q3", "Q4");
33                 initSubmodelComponents();
34         }
35
36         @SuppressWarnings("unused") // for GUIWires being created
37         private void initSubmodelComponents()
38         {
39                 Pin C = getSubmodelPin("C");
40                 Pin WE = getSubmodelPin("WE");
41                 Pin D1 = getSubmodelPin("D1");
42                 Pin D2 = getSubmodelPin("D2");
43                 Pin D3 = getSubmodelPin("D3");
44                 Pin D4 = getSubmodelPin("D4");
45                 Pin Q1 = getSubmodelPin("Q1");
46                 Pin Q2 = getSubmodelPin("Q2");
47                 Pin Q3 = getSubmodelPin("Q3");
48                 Pin Q4 = getSubmodelPin("Q4");
49
50                 GUIand and = new GUIand(submodelModifiable);
51                 dff1 = new GUIdff(submodelModifiable);
52                 dff2 = new GUIdff(submodelModifiable);
53                 dff3 = new GUIdff(submodelModifiable);
54                 dff4 = new GUIdff(submodelModifiable);
55
56                 WireCrossPoint cpC1 = new WireCrossPoint(submodelModifiable, 1);
57                 WireCrossPoint cpC2 = new WireCrossPoint(submodelModifiable, 1);
58                 WireCrossPoint cpC3 = new WireCrossPoint(submodelModifiable, 1);
59
60                 and.moveTo(5, 15);
61                 dff1.moveTo(50, 7.5);
62                 dff2.moveTo(50, 32.5);
63                 dff3.moveTo(50, 57.5);
64                 dff4.moveTo(50, 82.5);
65                 cpC1.moveCenterTo(42.5, 20);
66                 cpC2.moveCenterTo(42.5, 37.5);
67                 cpC3.moveCenterTo(42.5, 62.5);
68
69                 new GUIWire(submodelModifiable, C, and.getPin("A"));
70                 new GUIWire(submodelModifiable, WE, and.getPin("B"));
71                 new GUIWire(submodelModifiable, and.getPin("Y"), cpC1, new Point[0]);
72                 new GUIWire(submodelModifiable, cpC1, dff1.getPin("C"), new Point(42.5, 12.5));
73                 new GUIWire(submodelModifiable, cpC1, cpC2, new Point[0]);
74                 new GUIWire(submodelModifiable, cpC2, dff2.getPin("C"), new Point[0]);
75                 new GUIWire(submodelModifiable, cpC2, cpC3, new Point[0]);
76                 new GUIWire(submodelModifiable, cpC3, dff3.getPin("C"), new Point[0]);
77                 new GUIWire(submodelModifiable, cpC3, dff4.getPin("C"), new Point(42.5, 87.5));
78                 new GUIWire(submodelModifiable, D1, dff1.getPin("D"), new Point(17.5, 62.5), new Point(17.5, 42.5), new Point(45, 42.5),
79                                 new Point(45, 22.5));
80                 new GUIWire(submodelModifiable, D2, dff2.getPin("D"), new Point(22.5, 87.5), new Point(22.5, 47.5));
81                 new GUIWire(submodelModifiable, D3, dff3.getPin("D"), new Point(27.5, 112.5), new Point(27.5, 72.5));
82                 new GUIWire(submodelModifiable, D4, dff4.getPin("D"), new Point(32.5, 137.5), new Point(32.5, 97.5));
83                 new GUIWire(submodelModifiable, dff1.getPin("Q"), Q1, new Point[0]);
84                 new GUIWire(submodelModifiable, dff2.getPin("Q"), Q2, new Point[0]);
85                 new GUIWire(submodelModifiable, dff3.getPin("Q"), Q3, new Point[0]);
86                 new GUIWire(submodelModifiable, dff4.getPin("Q"), Q4, new Point[0]);
87
88                 addAtomicHighLevelStateID("q1");
89                 addAtomicHighLevelStateID("q2");
90                 addAtomicHighLevelStateID("q3");
91                 addAtomicHighLevelStateID("q4");
92                 addAtomicHighLevelStateID("q");
93         }
94
95         @Override
96         public void setAtomicHighLevelState(String stateID, Object newState)
97         {
98                 switch (stateID)
99                 {
100                 case "q1":
101                         dff1.setHighLevelState("q", newState);
102                         break;
103                 case "q2":
104                         dff2.setHighLevelState("q", newState);
105                         break;
106                 case "q3":
107                         dff3.setHighLevelState("q", newState);
108                         break;
109                 case "q4":
110                         dff4.setHighLevelState("q", newState);
111                         break;
112                 case "q":
113                         BitVector newStateCasted = (BitVector) newState;
114                         setHighLevelState("q1", newStateCasted.getBit(0));
115                         setHighLevelState("q2", newStateCasted.getBit(1));
116                         setHighLevelState("q3", newStateCasted.getBit(2));
117                         setHighLevelState("q4", newStateCasted.getBit(3));
118                         break;
119                 default:
120                         // should not happen because we tell SubmodelComponent to only allow these state IDs.
121                         throw new IllegalStateException("Illegal atomic state ID: " + stateID);
122                 }
123         }
124
125         @Override
126         public Object getAtomicHighLevelState(String stateID)
127         {
128                 switch (stateID)
129                 {
130                 case "q1":
131                         return dff1.getHighLevelState("q");
132                 case "q2":
133                         return dff2.getHighLevelState("q");
134                 case "q3":
135                         return dff3.getHighLevelState("q");
136                 case "q4":
137                         return dff4.getHighLevelState("q");
138                 case "q":
139                         Bit q1 = (Bit) getHighLevelState("q1");
140                         Bit q2 = (Bit) getHighLevelState("q2");
141                         Bit q3 = (Bit) getHighLevelState("q3");
142                         Bit q4 = (Bit) getHighLevelState("q4");
143                         return BitVector.of(q1, q2, q3, q4);
144                 default:
145                         // should not happen because we tell SubmodelComponent to only allow these state IDs.
146                         throw new IllegalStateException("Illegal atomic state ID: " + stateID);
147                 }
148         }
149
150         static
151         {
152                 IndirectGUIComponentCreator.setComponentSupplier(GUIAm2901QReg.class.getCanonicalName(), (m, p, n) -> new GUIAm2901QReg(m, n));
153         }
154 }