From 804d883ea4afa616be97e03f3cc75cea28011e61 Mon Sep 17 00:00:00 2001 From: rusefillc Date: Thu, 8 Oct 2020 23:23:45 -0400 Subject: [PATCH] please die on close --- .../src/main/java/com/rusefi/ui/util/FrameHelper.java | 7 +++++++ .../src/main/java/com/rusefi/ts_plugin/TuneUploadTab.java | 6 ++++-- .../test/java/com/rusefi/ts_plugin/PluginBodySandbox.java | 5 ++++- 3 files changed, 15 insertions(+), 3 deletions(-) diff --git a/java_console/autoupdate/src/main/java/com/rusefi/ui/util/FrameHelper.java b/java_console/autoupdate/src/main/java/com/rusefi/ui/util/FrameHelper.java index d317dfb23a..5d881f35c9 100644 --- a/java_console/autoupdate/src/main/java/com/rusefi/ui/util/FrameHelper.java +++ b/java_console/autoupdate/src/main/java/com/rusefi/ui/util/FrameHelper.java @@ -1,8 +1,10 @@ package com.rusefi.ui.util; import javax.swing.*; +import java.awt.*; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; +import java.util.Arrays; /** * Date: 3/24/13 @@ -38,6 +40,11 @@ public class FrameHelper { @Override public void windowClosed(WindowEvent ev) { onWindowClosed(); + for (Thread t : Thread.getAllStackTraces().keySet()) { + if (!t.isDaemon()) + System.out.println("Non-daemon thread: " + t); + } + System.out.println(Arrays.toString(Frame.getFrames())); } }); frame.add(component); diff --git a/java_tools/ts_plugin/src/main/java/com/rusefi/ts_plugin/TuneUploadTab.java b/java_tools/ts_plugin/src/main/java/com/rusefi/ts_plugin/TuneUploadTab.java index 7d933b04b3..3906059aa2 100644 --- a/java_tools/ts_plugin/src/main/java/com/rusefi/ts_plugin/TuneUploadTab.java +++ b/java_tools/ts_plugin/src/main/java/com/rusefi/ts_plugin/TuneUploadTab.java @@ -5,6 +5,7 @@ import com.efiAnalytics.plugin.ecu.ControllerException; import com.efiAnalytics.plugin.ecu.ControllerParameterChangeListener; import com.opensr5.ini.IniFileModel; import com.opensr5.ini.field.IniField; +import com.rusefi.NamedThreadFactory; import com.rusefi.TsTuneReader; import com.rusefi.config.generated.Fields; import com.rusefi.tools.online.Online; @@ -21,6 +22,7 @@ import java.awt.*; import java.awt.event.ActionEvent; import java.util.Date; import java.util.Map; +import java.util.concurrent.ThreadFactory; import java.util.function.Supplier; /** @@ -30,6 +32,7 @@ public class TuneUploadTab { private final JComponent content = new JPanel(new VerticalFlowLayout()); // 2 seconds aggregation by default private static final int AUTO_UPDATE_AGGREGATION = Integer.parseInt(System.getProperty("autoupload.aggregation", "2000")); + private static final ThreadFactory THREAD_FACTORY = new NamedThreadFactory("Tune Upload", true); private static final String REO_URL = "https://rusefi.com/online/"; private final AuthTokenPanel tokenPanel = new AuthTokenPanel(); @@ -69,7 +72,7 @@ public class TuneUploadTab { }; upload.setBackground(new Color(0x90EE90)); - Thread t = new Thread(new Runnable() { + Thread t = THREAD_FACTORY.newThread(new Runnable() { @Override public void run() { while (true) { @@ -98,7 +101,6 @@ public class TuneUploadTab { } } }); - t.setDaemon(true); t.start(); upload.addActionListener(new AbstractAction() { diff --git a/java_tools/ts_plugin/src/test/java/com/rusefi/ts_plugin/PluginBodySandbox.java b/java_tools/ts_plugin/src/test/java/com/rusefi/ts_plugin/PluginBodySandbox.java index 4161a6b41d..bfa3caace7 100644 --- a/java_tools/ts_plugin/src/test/java/com/rusefi/ts_plugin/PluginBodySandbox.java +++ b/java_tools/ts_plugin/src/test/java/com/rusefi/ts_plugin/PluginBodySandbox.java @@ -7,6 +7,7 @@ import com.opensr5.ini.IniFileModel; import com.rusefi.TsTuneReader; import com.rusefi.ui.util.FrameHelper; +import javax.swing.*; import java.util.ArrayList; import java.util.Objects; @@ -38,7 +39,9 @@ public class PluginBodySandbox { doReturn(new String[]{PROJECT_NAME}).when(controllerAccess).getEcuConfigurationNames(); doReturn(controllerParameterServer).when(controllerAccess).getControllerParameterServer(); - new FrameHelper().showFrame(new PluginEntry(() -> controllerAccess).getContent()); + FrameHelper frameHelper = new FrameHelper(); + frameHelper.getFrame().setDefaultCloseOperation(JDialog.EXIT_ON_CLOSE); + frameHelper.showFrame(new PluginEntry(() -> controllerAccess).getContent()); } }