1 package net.mograsim.logic.ui.model.components.mi.nandbased;
3 import net.haspamelodica.swt.helper.swtobjectwrappers.Point;
4 import net.mograsim.logic.ui.model.ViewModelModifiable;
5 import net.mograsim.logic.ui.model.components.GUINandGate;
6 import net.mograsim.logic.ui.model.components.SimpleRectangularSubmodelComponent;
7 import net.mograsim.logic.ui.model.wires.GUIWire;
8 import net.mograsim.logic.ui.model.wires.Pin;
10 public class GUIfulladder extends SimpleRectangularSubmodelComponent
12 public GUIfulladder(ViewModelModifiable model)
14 super(model, 1, "GUIfulladder");
19 initSubmodelComponents();
22 @SuppressWarnings("unused") // for GUIWires being created
23 private void initSubmodelComponents()
25 Pin A = getInputSubmodelPins().get(0);
26 Pin B = getInputSubmodelPins().get(1);
27 Pin C = getInputSubmodelPins().get(2);
28 Pin Y = getOutputSubmodelPins().get(0);
29 Pin Z = getOutputSubmodelPins().get(1);
31 GUIhalfadder halfBC = new GUIhalfadder(submodelModifiable);
32 GUIhalfadder halfAY = new GUIhalfadder(submodelModifiable);
33 GUINandGate nandZ = new GUINandGate(submodelModifiable, 1);
35 halfAY.moveTo(45, 7.5);
37 nandZ.moveTo(57.5, 40);
39 new GUIWire(submodelModifiable, A, halfAY.getInputPins().get(0), new Point[0]);
40 new GUIWire(submodelModifiable, B, halfBC.getInputPins().get(0));
41 new GUIWire(submodelModifiable, C, halfBC.getInputPins().get(1));
42 new GUIWire(submodelModifiable, halfBC.getOutputPins().get(0), halfAY.getInputPins().get(1));
43 new GUIWire(submodelModifiable, halfBC.getOutputPins().get(1), nandZ.getInputPins().get(1), new Point[0]);
44 new GUIWire(submodelModifiable, halfAY.getOutputPins().get(0), Y, new Point[0]);
45 new GUIWire(submodelModifiable, halfAY.getOutputPins().get(1), nandZ.getInputPins().get(0), new Point(82.5, 22.5),
46 new Point(82.5, 35), new Point(52.5, 35), new Point(52.5, 45));
47 new GUIWire(submodelModifiable, nandZ.getOutputPin(), Z);