Restructured Snippet support:
[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 java.util.Arrays;
4
5 import net.haspamelodica.swt.helper.swtobjectwrappers.Point;
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 import net.mograsim.logic.model.snippets.highlevelstatehandlers.standard.StandardHighLevelStateHandler;
15 import net.mograsim.logic.model.snippets.highlevelstatehandlers.standard.atomic.BitVectorSplittingAtomicHighLevelStateHandler;
16 import net.mograsim.logic.model.snippets.highlevelstatehandlers.standard.atomic.DelegatingAtomicHighLevelStateHandler;
17
18 public class GUIAm2901QReg extends SimpleRectangularSubmodelComponent
19 {
20         public GUIAm2901QReg(ViewModelModifiable model)
21         {
22                 this(model, null);
23         }
24
25         public GUIAm2901QReg(ViewModelModifiable model, String name)
26         {
27                 super(model, 1, "GUIAm2901QReg", name);
28                 setSubmodelScale(.4);
29                 setInputPins("C", "WE", "D1", "D2", "D3", "D4");
30                 setOutputPins("Q1", "Q2", "Q3", "Q4");
31                 initSubmodelComponents();
32         }
33
34         @SuppressWarnings("unused") // for GUIWires being created
35         private void initSubmodelComponents()
36         {
37                 Pin C = getSubmodelPin("C");
38                 Pin WE = getSubmodelPin("WE");
39                 Pin D1 = getSubmodelPin("D1");
40                 Pin D2 = getSubmodelPin("D2");
41                 Pin D3 = getSubmodelPin("D3");
42                 Pin D4 = getSubmodelPin("D4");
43                 Pin Q1 = getSubmodelPin("Q1");
44                 Pin Q2 = getSubmodelPin("Q2");
45                 Pin Q3 = getSubmodelPin("Q3");
46                 Pin Q4 = getSubmodelPin("Q4");
47
48                 GUIand and = new GUIand(submodelModifiable);
49                 GUIdff dff1 = new GUIdff(submodelModifiable);
50                 GUIdff dff2 = new GUIdff(submodelModifiable);
51                 GUIdff dff3 = new GUIdff(submodelModifiable);
52                 GUIdff dff4 = new GUIdff(submodelModifiable);
53
54                 WireCrossPoint cpC1 = new WireCrossPoint(submodelModifiable, 1);
55                 WireCrossPoint cpC2 = new WireCrossPoint(submodelModifiable, 1);
56                 WireCrossPoint cpC3 = new WireCrossPoint(submodelModifiable, 1);
57
58                 and.moveTo(5, 15);
59                 dff1.moveTo(50, 7.5);
60                 dff2.moveTo(50, 32.5);
61                 dff3.moveTo(50, 57.5);
62                 dff4.moveTo(50, 82.5);
63                 cpC1.moveCenterTo(42.5, 20);
64                 cpC2.moveCenterTo(42.5, 37.5);
65                 cpC3.moveCenterTo(42.5, 62.5);
66
67                 new GUIWire(submodelModifiable, C, and.getPin("A"));
68                 new GUIWire(submodelModifiable, WE, and.getPin("B"));
69                 new GUIWire(submodelModifiable, and.getPin("Y"), cpC1, new Point[0]);
70                 new GUIWire(submodelModifiable, cpC1, dff1.getPin("C"), new Point(42.5, 12.5));
71                 new GUIWire(submodelModifiable, cpC1, cpC2, new Point[0]);
72                 new GUIWire(submodelModifiable, cpC2, dff2.getPin("C"), new Point[0]);
73                 new GUIWire(submodelModifiable, cpC2, cpC3, new Point[0]);
74                 new GUIWire(submodelModifiable, cpC3, dff3.getPin("C"), new Point[0]);
75                 new GUIWire(submodelModifiable, cpC3, dff4.getPin("C"), new Point(42.5, 87.5));
76                 new GUIWire(submodelModifiable, D1, dff1.getPin("D"), new Point(17.5, 62.5), new Point(17.5, 42.5), new Point(45, 42.5),
77                                 new Point(45, 22.5));
78                 new GUIWire(submodelModifiable, D2, dff2.getPin("D"), new Point(22.5, 87.5), new Point(22.5, 47.5));
79                 new GUIWire(submodelModifiable, D3, dff3.getPin("D"), new Point(27.5, 112.5), new Point(27.5, 72.5));
80                 new GUIWire(submodelModifiable, D4, dff4.getPin("D"), new Point(32.5, 137.5), new Point(32.5, 97.5));
81                 new GUIWire(submodelModifiable, dff1.getPin("Q"), Q1, new Point[0]);
82                 new GUIWire(submodelModifiable, dff2.getPin("Q"), Q2, new Point[0]);
83                 new GUIWire(submodelModifiable, dff3.getPin("Q"), Q3, new Point[0]);
84                 new GUIWire(submodelModifiable, dff4.getPin("Q"), Q4, new Point[0]);
85
86                 StandardHighLevelStateHandler highLevelStateHandler = new StandardHighLevelStateHandler(this);
87                 highLevelStateHandler.addAtomicHighLevelState("q1", DelegatingAtomicHighLevelStateHandler::new).set(dff1, "q");
88                 highLevelStateHandler.addAtomicHighLevelState("q2", DelegatingAtomicHighLevelStateHandler::new).set(dff2, "q");
89                 highLevelStateHandler.addAtomicHighLevelState("q3", DelegatingAtomicHighLevelStateHandler::new).set(dff3, "q");
90                 highLevelStateHandler.addAtomicHighLevelState("q4", DelegatingAtomicHighLevelStateHandler::new).set(dff4, "q");
91                 highLevelStateHandler.addAtomicHighLevelState("q", BitVectorSplittingAtomicHighLevelStateHandler::new)
92                                 .set(Arrays.asList("q1", "q2", "q3", "q4"), Arrays.asList(1, 1, 1, 1));
93                 setHighLevelStateHandler(highLevelStateHandler);
94         }
95
96         static
97         {
98                 IndirectGUIComponentCreator.setComponentSupplier(GUIAm2901QReg.class.getCanonicalName(), (m, p, n) -> new GUIAm2901QReg(m, n));
99         }
100 }