Wires connected to a component now get deleted with the component
[Mograsim.git] / net.mograsim.logic.model / src / net / mograsim / logic / model / model / components / atomic / ModelSplitter.java
index 2f7a98d..805831f 100644 (file)
@@ -6,11 +6,11 @@ import net.haspamelodica.swt.helper.gcs.GeneralGC;
 import net.haspamelodica.swt.helper.swtobjectwrappers.Rectangle;
 import net.mograsim.logic.core.types.BitVectorFormatter;
 import net.mograsim.logic.core.wires.CoreWire.ReadEnd;
-import net.mograsim.logic.model.model.ViewModelModifiable;
+import net.mograsim.logic.model.model.LogicModelModifiable;
 import net.mograsim.logic.model.model.components.ModelComponent;
 import net.mograsim.logic.model.model.wires.Pin;
 import net.mograsim.logic.model.model.wires.PinUsage;
-import net.mograsim.logic.model.modeladapter.ViewLogicModelAdapter;
+import net.mograsim.logic.model.modeladapter.LogicCoreAdapter;
 import net.mograsim.logic.model.modeladapter.componentadapters.SplitterAdapter;
 import net.mograsim.logic.model.serializing.IdentifyParams;
 import net.mograsim.logic.model.serializing.IndirectModelComponentCreator;
@@ -29,20 +29,20 @@ public class ModelSplitter extends ModelComponent
        private ReadEnd inputEnd;
        private final ReadEnd[] outputEnds;
 
-       public ModelSplitter(ViewModelModifiable model, int logicWidth)
+       public ModelSplitter(LogicModelModifiable model, int logicWidth)
        {
                this(model, logicWidth, null);
        }
 
-       public ModelSplitter(ViewModelModifiable model, int logicWidth, String name)
+       public ModelSplitter(LogicModelModifiable model, int logicWidth, String name)
        {
                super(model, name);
                this.logicWidth = logicWidth;
                setSize(width, (logicWidth - 1) * heightPerPin);
-               addPin(this.inputPin = new Pin(this, "I", logicWidth, PinUsage.TRISTATE, 0, (logicWidth - 1) * heightPerPin / 2));
+               addPin(this.inputPin = new Pin(model, this, "I", logicWidth, PinUsage.TRISTATE, 0, (logicWidth - 1) * heightPerPin / 2));
                double outputHeight = (logicWidth - 1) * heightPerPin;
                for (int i = 0; i < logicWidth; i++, outputHeight -= 10)
-                       addPin(new Pin(this, "O" + i, 1, PinUsage.TRISTATE, width, outputHeight));
+                       addPin(new Pin(model, this, "O" + i, 1, PinUsage.TRISTATE, width, outputHeight));
                outputEnds = new ReadEnd[logicWidth];
        }
 
@@ -91,7 +91,7 @@ public class ModelSplitter extends ModelComponent
                return logicWidth;
        }
 
-       public void setLogicModelBinding(ReadEnd inputEnd, ReadEnd[] outputEnds)
+       public void setCoreModelBinding(ReadEnd inputEnd, ReadEnd[] outputEnds)
        {
                this.inputEnd = inputEnd;
                System.arraycopy(outputEnds, 0, this.outputEnds, 0, logicWidth);
@@ -104,7 +104,7 @@ public class ModelSplitter extends ModelComponent
 
        static
        {
-               ViewLogicModelAdapter.addComponentAdapter(new SplitterAdapter());
+               LogicCoreAdapter.addComponentAdapter(new SplitterAdapter());
                IndirectModelComponentCreator.setComponentSupplier(ModelSplitter.class.getCanonicalName(),
                                (m, p, n) -> new ModelSplitter(m, p.getAsInt(), n));
        }