import net.haspamelodica.swt.helper.swtobjectwrappers.Point;
import net.haspamelodica.swt.helper.swtobjectwrappers.Rectangle;
import net.mograsim.logic.model.editor.states.EditorState;
-import net.mograsim.logic.model.model.wires.GUIWire;
-import net.mograsim.logic.model.model.wires.GUIWire.PathChangedListener;
+import net.mograsim.logic.model.model.LogicModelModifiable;
+import net.mograsim.logic.model.model.wires.ModelWire;
-public class WireHandle extends Handle implements PathChangedListener
+public class WireHandle extends Handle
{
private boolean selected = false;
private final static double WIDTH = 2.0;
private final static double WIDTH_SQUARED = WIDTH * WIDTH;
- public final GUIWire parent;
+ private final LogicModelModifiable model;
+ public final ModelWire parent;
- public WireHandle(GUIWire parent)
+ public WireHandle(LogicModelModifiable model, ModelWire parent)
{
+ super(5);
+ this.model = model;
this.parent = parent;
- parent.addPathChangedListener(this);
+ parent.addPathChangedListener(c -> updateBounds());
updateBounds();
}
void destroy()
{
super.destroy();
- parent.removePathChangedListener(this);
+ parent.removePathChangedListener(c -> updateBounds());
}
public void updateBounds()
@Override
public void reqDelete()
{
- parent.destroy();
+ // this wire could already be removed implicitly when removing a selection containing both wires and components
+ if (model.getWireByName(parent.name) != null)
+ model.destroyWire(parent);
}
@Override
}
- private static Optional<WireClickData> click(GUIWire w, double x, double y)
+ private static Optional<WireClickData> click(ModelWire w, double x, double y)
{
Rectangle modifiedBounds = w.getBounds();
modifiedBounds.x -= WIDTH;
{
return HandleType.WIRE;
}
-
- @Override
- public void pathChanged(GUIWire wire, int diff)
- {
- updateBounds();
- }
}