diff --git a/HMCL/src/main/java/org/jackhuang/hmcl/ui/construct/TaskListPane.java b/HMCL/src/main/java/org/jackhuang/hmcl/ui/construct/TaskListPane.java index abad96e49..9c5311d53 100644 --- a/HMCL/src/main/java/org/jackhuang/hmcl/ui/construct/TaskListPane.java +++ b/HMCL/src/main/java/org/jackhuang/hmcl/ui/construct/TaskListPane.java @@ -279,7 +279,7 @@ public final class TaskListPane extends StackPane { private final JFXProgressBar bar = new JFXProgressBar(); private WeakReference prevStageNodeRef; - private ChangeListener statusChangeListener; + private StatusChangeListener statusChangeListener; private Cell() { setPadding(new Insets(0, 0, 4, 0)); @@ -364,32 +364,32 @@ public final class TaskListPane extends StackPane { pane.setBottom(null); } } + } - private final class StatusChangeListener implements ChangeListener, WeakListener { + private static final class StatusChangeListener implements ChangeListener, WeakListener { - private final WeakReference cellRef; + private final WeakReference cellRef; - private StatusChangeListener(Cell cell) { - this.cellRef = new WeakReference<>(cell); - } - - @Override - public boolean wasGarbageCollected() { - return cellRef.get() == null; - } - - @Override - public void changed(ObservableValue observable, - StageNode.Status oldValue, - StageNode.Status newValue) { - Cell cell = cellRef.get(); - if (cell == null) { - if (observable != null) - observable.removeListener(this); - return; - } - cell.updateLeftIcon(newValue); + private StatusChangeListener(Cell cell) { + this.cellRef = new WeakReference<>(cell); + } + + @Override + public boolean wasGarbageCollected() { + return cellRef.get() == null; + } + + @Override + public void changed(ObservableValue observable, + StageNode.Status oldValue, + StageNode.Status newValue) { + Cell cell = cellRef.get(); + if (cell == null) { + if (observable != null) + observable.removeListener(this); + return; } + cell.updateLeftIcon(newValue); } }