From bf11c7f3950c2bea4a4cd2ec9b8e8a870c5730f2 Mon Sep 17 00:00:00 2001 From: Martino Facchin Date: Wed, 6 Apr 2016 17:52:24 +0200 Subject: [PATCH] avoid queuing a lot of threads while waiting for platform --- .../discoverers/serial/SerialBoardsLister.java | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/arduino-core/src/cc/arduino/packages/discoverers/serial/SerialBoardsLister.java b/arduino-core/src/cc/arduino/packages/discoverers/serial/SerialBoardsLister.java index 0cafed956..77d2922e7 100644 --- a/arduino-core/src/cc/arduino/packages/discoverers/serial/SerialBoardsLister.java +++ b/arduino-core/src/cc/arduino/packages/discoverers/serial/SerialBoardsLister.java @@ -56,13 +56,6 @@ public class SerialBoardsLister extends TimerTask { } public synchronized void retriggerDiscovery(boolean polled) { - while (BaseNoGui.packages == null) { - try { - Thread.sleep(1000); - } catch (InterruptedException e) { - // noop - } - } Platform platform = BaseNoGui.getPlatform(); if (platform == null) { return; @@ -103,6 +96,11 @@ public class SerialBoardsLister extends TimerTask { String[] parts = newPort.split("_"); String port = parts[0]; + if (parts.length != 3) { + // something went horribly wrong + continue; + } + Map boardData = platform.resolveDeviceByVendorIdProductId(port, BaseNoGui.packages); BoardPort boardPort = null; @@ -168,6 +166,9 @@ public class SerialBoardsLister extends TimerTask { @Override public void run() { + if (BaseNoGui.packages == null) { + return; + } retriggerDiscovery(true); } }