+++ /dev/null
-package net.mograsim.logic.model.model.components.mi.nandbased;
-
-import java.util.Arrays;
-
-import net.haspamelodica.swt.helper.swtobjectwrappers.Point;
-import net.mograsim.logic.model.model.ViewModelModifiable;
-import net.mograsim.logic.model.model.components.submodels.SimpleRectangularSubmodelComponent;
-import net.mograsim.logic.model.model.wires.GUIWire;
-import net.mograsim.logic.model.model.wires.Pin;
-import net.mograsim.logic.model.model.wires.WireCrossPoint;
-import net.mograsim.logic.model.serializing.IndirectGUIComponentCreator;
-import net.mograsim.logic.model.snippets.highlevelstatehandlers.standard.StandardHighLevelStateHandler;
-import net.mograsim.logic.model.snippets.highlevelstatehandlers.standard.atomic.BitVectorSplittingAtomicHighLevelStateHandler;
-import net.mograsim.logic.model.snippets.highlevelstatehandlers.standard.atomic.DelegatingAtomicHighLevelStateHandler;
-
-public class GUIdlatch4 extends SimpleRectangularSubmodelComponent
-{
- public GUIdlatch4(ViewModelModifiable model)
- {
- this(model, null);
- }
-
- public GUIdlatch4(ViewModelModifiable model, String name)
- {
- super(model, 1, "GUIdlatch4", name);
- setSubmodelScale(.4);
- setInputPins("D1", "D2", "D3", "D4", "C");
- setOutputPins("Q1", "Q2", "Q3", "Q4");
- initSubmodelComponents();
- }
-
- @SuppressWarnings("unused") // for GUIWires being created
- private void initSubmodelComponents()
- {
- Pin D1 = getSubmodelPin("D1");
- Pin D2 = getSubmodelPin("D2");
- Pin D3 = getSubmodelPin("D3");
- Pin D4 = getSubmodelPin("D4");
- Pin C = getSubmodelPin("C");
- Pin Q1 = getSubmodelPin("Q1");
- Pin Q2 = getSubmodelPin("Q2");
- 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);
-
- WireCrossPoint cp2 = new WireCrossPoint(submodelModifiable, 1);
- WireCrossPoint cp3 = new WireCrossPoint(submodelModifiable, 1);
- WireCrossPoint cp4 = new WireCrossPoint(submodelModifiable, 1);
-
- dlatch1.moveTo(30, 7.5);
- dlatch2.moveTo(30, 32.5);
- dlatch3.moveTo(30, 57.5);
- dlatch4.moveTo(30, 82.5);
- cp2.moveCenterTo(15, 47.5);
- cp3.moveCenterTo(15, 72.5);
- cp4.moveCenterTo(15, 97.5);
-
- new GUIWire(submodelModifiable, C, cp4, new Point(15, 112.5));
- new GUIWire(submodelModifiable, cp4, dlatch4.getPin("E"), new Point[0]);
- new GUIWire(submodelModifiable, cp4, cp3, new Point[0]);
- new GUIWire(submodelModifiable, cp3, dlatch3.getPin("E"), new Point[0]);
- new GUIWire(submodelModifiable, cp3, cp2, new Point[0]);
- new GUIWire(submodelModifiable, cp2, dlatch2.getPin("E"), new Point[0]);
- new GUIWire(submodelModifiable, cp2, dlatch1.getPin("E"), new Point(15, 22.5));
- new GUIWire(submodelModifiable, D1, dlatch1.getPin("D"), new Point[0]);
- new GUIWire(submodelModifiable, D2, dlatch2.getPin("D"), new Point[0]);
- new GUIWire(submodelModifiable, D3, dlatch3.getPin("D"), new Point[0]);
- new GUIWire(submodelModifiable, D4, dlatch4.getPin("D"), new Point[0]);
- new GUIWire(submodelModifiable, dlatch1.getPin("Q"), Q1, new Point[0]);
- new GUIWire(submodelModifiable, dlatch2.getPin("Q"), Q2, new Point[0]);
- new GUIWire(submodelModifiable, dlatch3.getPin("Q"), Q3, new Point[0]);
- new GUIWire(submodelModifiable, dlatch4.getPin("Q"), Q4, new Point[0]);
-
- StandardHighLevelStateHandler highLevelStateHandler = new StandardHighLevelStateHandler(this);
- highLevelStateHandler.addAtomicHighLevelState("q1", DelegatingAtomicHighLevelStateHandler::new).set(dlatch1, "q");
- highLevelStateHandler.addAtomicHighLevelState("q2", DelegatingAtomicHighLevelStateHandler::new).set(dlatch2, "q");
- highLevelStateHandler.addAtomicHighLevelState("q3", DelegatingAtomicHighLevelStateHandler::new).set(dlatch3, "q");
- highLevelStateHandler.addAtomicHighLevelState("q4", DelegatingAtomicHighLevelStateHandler::new).set(dlatch4, "q");
- highLevelStateHandler.addAtomicHighLevelState("q", BitVectorSplittingAtomicHighLevelStateHandler::new)
- .set(Arrays.asList("q1", "q2", "q3", "q4"), Arrays.asList(1, 1, 1, 1));
- setHighLevelStateHandler(highLevelStateHandler);
- }
-
- static
- {
- IndirectGUIComponentCreator.setComponentSupplier(GUIdlatch4.class.getCanonicalName(), (m, p, n) -> new GUIdlatch4(m, n));
- }
-}
\ No newline at end of file