X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=net.mograsim.logic.model.editor%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fmodel%2Feditor%2Fhandles%2FHandleManager.java;h=91b0e3b07630d2ce32903a04edcab2b835a5ff3a;hb=c5c0d07286a29994a11ba8b01eaffb21964b6c1b;hp=f999c96a28324d690a23127c70596d6ee08ff46a;hpb=a393b0a2a9899707af54c9ee77a01f28ac967bd1;p=Mograsim.git diff --git a/net.mograsim.logic.model.editor/src/net/mograsim/logic/model/editor/handles/HandleManager.java b/net.mograsim.logic.model.editor/src/net/mograsim/logic/model/editor/handles/HandleManager.java index f999c96a..91b0e3b0 100644 --- a/net.mograsim.logic.model.editor/src/net/mograsim/logic/model/editor/handles/HandleManager.java +++ b/net.mograsim.logic.model.editor/src/net/mograsim/logic/model/editor/handles/HandleManager.java @@ -123,13 +123,6 @@ public class HandleManager for(int i = 0; i < diff; i++) addWirePointHandle(w); } - else - { - for(int i = 0; i > diff; i--) - { - removeLastWirePointHandle(wire); - } - } List wpHandles = pointHandlesPerWire.get(w); int size = wpHandles.size(); @@ -203,23 +196,25 @@ public class HandleManager List wireHandles = pointHandlesPerWire.get(w); WirePointHandle h; if (wireHandles != null) - wireHandles.add(h = new WirePointHandle(w, wireHandles.size())); + wireHandles.add(h = new WirePointHandle(this, w, wireHandles.size())); else { wireHandles = new ArrayList<>(); - h = new WirePointHandle(w, 0); + h = new WirePointHandle(this, w, 0); wireHandles.add(h); pointHandlesPerWire.put(h.parent, wireHandles); } this.wirePointHandles.add(h); addHandle(h); } - - private void removeLastWirePointHandle(GUIWire owner) + + void destroyWirePointHandle(GUIWire owner, WirePointHandle h) { - Handle h = pointHandlesPerWire.get(owner).remove(0); - wirePointHandles.remove(h); + List handles = pointHandlesPerWire.get(owner); + int pointIndex = handles.indexOf(h); + handles.remove(pointIndex); removeHandle(h); + owner.removePathPoint(pointIndex); } private void removeWirePointHandles(GUIWire owner) @@ -345,9 +340,9 @@ public class HandleManager if (!click(handlePerPin.values(), clicked, entryState, stateMask)) if (!click(handlePerInterfacePin.values(), clicked, entryState, stateMask)) if (!click(getWirePointHandles(), clicked, entryState, stateMask)) - if (!click(handlePerComp.values(), clicked, entryState, stateMask)) - if (!click(getWireHandles(), clicked, entryState, stateMask)) - entryState.clickedEmpty(clicked, stateMask); + if (!click(getWireHandles(), clicked, entryState, stateMask)) + if (!click(handlePerComp.values(), clicked, entryState, stateMask)) + entryState.clickedEmpty(clicked, stateMask); entryState.clicked(clicked, stateMask); }