package era.mi.gui;
+import java.util.function.Consumer;
+
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Event;
this.model = model;
- model.addComponentAddedListener(c -> redrawThreadsafe());
- model.addWireAddedListener(c -> redrawThreadsafe());
- model.addComponentRemovedListener(c -> redrawThreadsafe());
- model.addWireRemovedListener(c -> redrawThreadsafe());
+ Consumer<Object> redrawConsumer = o -> redrawThreadsafe();
+ Consumer<Pin> pinAddedListener = p ->
+ {
+ p.addPinMovedListener(redrawConsumer);
+ redrawThreadsafe();
+ };
+ Consumer<Pin> pinRemovedListener = p ->
+ {
+ p.removePinMovedListener(redrawConsumer);
+ redrawThreadsafe();
+ };
+ model.addComponentAddedListener(c ->
+ {
+ c.addComponentChangedListener(redrawConsumer);
+ c.addComponentMovedListener(redrawConsumer);
+ c.addPinAddedListener(pinAddedListener);
+ c.addPinRemovedListener(pinRemovedListener);
+ redrawThreadsafe();
+ });
+ model.addComponentRemovedListener(c ->
+ {
+ c.removeComponentChangedListener(redrawConsumer);
+ c.removeComponentMovedListener(redrawConsumer);
+ c.removePinAddedListener(pinAddedListener);
+ c.removePinRemovedListener(pinRemovedListener);
+ redrawThreadsafe();
+ });
+ model.addWireAddedListener(w ->
+ {
+ w.addWireChangedListener(redrawConsumer);
+ redrawThreadsafe();
+ });
+ model.addWireRemovedListener(w ->
+ {
+ w.removeWireChangedListener(redrawConsumer);
+ redrawThreadsafe();
+ });
addZoomedRenderer(gc ->
{