Commit 88c1c1a3 authored by Guillaume Seguin's avatar Guillaume Seguin

Properly quit gcode and viz loading threads when quitting Pronterface

parent 5e20fcce
...@@ -54,6 +54,11 @@ layerindex = 0 ...@@ -54,6 +54,11 @@ layerindex = 0
if os.name == "nt": if os.name == "nt":
winsize = (800, 530) winsize = (800, 530)
pronterface_quitting = False
class PronterfaceQuitException(Exception):
pass
from printrun.gui import MainWindow from printrun.gui import MainWindow
from printrun.excluder import Excluder from printrun.excluder import Excluder
from pronsole import dosify, wxSetting, HiddenSetting, StringSetting, SpinSetting, FloatSpinSetting, BooleanSetting, StaticTextSetting from pronsole import dosify, wxSetting, HiddenSetting, StringSetting, SpinSetting, FloatSpinSetting, BooleanSetting, StaticTextSetting
...@@ -295,6 +300,8 @@ class PronterWindow(MainWindow, pronsole.pronsole): ...@@ -295,6 +300,8 @@ class PronterWindow(MainWindow, pronsole.pronsole):
self.Close() self.Close()
def kill(self, e): def kill(self, e):
global pronterface_quitting
pronterface_quitting = True
self.statuscheck = False self.statuscheck = False
if self.status_thread: if self.status_thread:
self.status_thread.join() self.status_thread.join()
...@@ -1337,12 +1344,18 @@ Printrun. If not, see <http://www.gnu.org/licenses/>.""" ...@@ -1337,12 +1344,18 @@ Printrun. If not, see <http://www.gnu.org/licenses/>."""
# FIXME: this thread and the loadviz one are not tracked at all # FIXME: this thread and the loadviz one are not tracked at all
def load_gcode_async_thread(self, gcode): def load_gcode_async_thread(self, gcode):
self.load_gcode(self.filename, try:
layer_callback = self.layer_ready_cb, self.load_gcode(self.filename,
gcode = gcode) layer_callback = self.layer_ready_cb,
gcode = gcode)
except PronterfaceQuitException:
return
wx.CallAfter(self.post_gcode_load) wx.CallAfter(self.post_gcode_load)
def layer_ready_cb(self, gcode, layer): def layer_ready_cb(self, gcode, layer):
global pronterface_quitting
if pronterface_quitting:
raise PronterfaceQuitException
self.viz_last_layer = layer self.viz_last_layer = layer
if time.time() - self.viz_last_yield > 0.8: if time.time() - self.viz_last_yield > 0.8:
time.sleep(0.2) time.sleep(0.2)
...@@ -1399,6 +1412,9 @@ Printrun. If not, see <http://www.gnu.org/licenses/>.""" ...@@ -1399,6 +1412,9 @@ Printrun. If not, see <http://www.gnu.org/licenses/>."""
# During preloading we verify that the layer we added is the one we # During preloading we verify that the layer we added is the one we
# expected through the assert call. # expected through the assert call.
while True: while True:
global pronterface_quitting
if pronterface_quitting:
return
max_layer = self.viz_last_layer max_layer = self.viz_last_layer
if max_layer is None: if max_layer is None:
break break
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment