Plugins/CheckerPlugins/SyntaxChecker/SyntaxCheck.py

changeset 5672
495b53f37f6c
parent 5616
adcffadf4962
child 5683
66b11f5171e8
diff -r 47cc72334684 -r 495b53f37f6c Plugins/CheckerPlugins/SyntaxChecker/SyntaxCheck.py
--- a/Plugins/CheckerPlugins/SyntaxChecker/SyntaxCheck.py	Fri Mar 31 17:28:12 2017 +0200
+++ b/Plugins/CheckerPlugins/SyntaxChecker/SyntaxCheck.py	Fri Mar 31 17:29:55 2017 +0200
@@ -13,6 +13,7 @@
 import sys
 import traceback
 import multiprocessing
+import queue
 
 try:
     from pyflakes.checker import Checker
@@ -147,11 +148,25 @@
     # Get and send results
     endIndex = len(argumentsList) - initialTasks
     for i in range(len(argumentsList)):
-        filename, result = doneQueue.get()
-        send(fx, filename, result)
-        if cancelled():
+        resultSent = False
+        wasCancelled = False
+        
+        while not resultSent:
+            try:
+                # get result (waiting max. 3 seconds and send it to frontend
+                filename, result = doneQueue.get()
+                send(fx, filename, result)
+                resultSent = True
+            except queue.Empty:
+                # ignore empty queue, just carry on
+                if cancelled():
+                    wasCancelled = True
+                    break
+        
+        if wasCancelled or cancelled():
             # just exit the loop ignoring the results of queued tasks
             break
+        
         if i < endIndex:
             taskQueue.put(argumentsList[i + initialTasks])
 

eric ide

mercurial