pause_resume: Implement send_pause_command()

This allows for pausing from inside a reactor callback.

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Arksine 2019-02-24 12:28:30 -05:00 committed by KevinOConnor
parent c8d7e28a35
commit 3cd1f9676d
2 changed files with 18 additions and 9 deletions

View File

@ -13,6 +13,7 @@ class PauseResume:
self.captured_speed = 0. self.captured_speed = 0.
self.captured_epos = None self.captured_epos = None
self.toolhead = self.v_sd = None self.toolhead = self.v_sd = None
self.pause_command_sent = False
self.sd_paused = False self.sd_paused = False
self.printer.register_event_handler("klippy:ready", self.handle_ready) self.printer.register_event_handler("klippy:ready", self.handle_ready)
self.gcode.register_command("PAUSE", self.cmd_PAUSE) self.gcode.register_command("PAUSE", self.cmd_PAUSE)
@ -25,17 +26,22 @@ class PauseResume:
return { return {
'is_paused': paused 'is_paused': paused
} }
def send_pause_command(self):
# This sends the appropriate pause command from an event.
if not self.pause_command_sent:
if self.v_sd is not None and self.v_sd.is_active():
# Printing from virtual sd, run pause command
self.sd_paused = True
self.v_sd.do_pause()
else:
self.sd_paused = False
self.gcode.respond_info("action:pause")
self.pause_command_sent = True
def cmd_PAUSE(self, params): def cmd_PAUSE(self, params):
if self.captured_position is not None: if self.captured_position is not None:
self.gcode.respond_info("Print already paused") self.gcode.respond_info("Print already paused")
return return
if self.v_sd is not None and self.v_sd.is_active(): self.send_pause_command()
# Printing from virtual sd, run pause command
self.sd_paused = True
self.v_sd.cmd_M25({})
else:
self.sd_paused = False
self.gcode.respond_info("action:pause")
self.toolhead.wait_moves() self.toolhead.wait_moves()
self.captured_position = self.toolhead.get_position() self.captured_position = self.toolhead.get_position()
reactor = self.printer.get_reactor() reactor = self.printer.get_reactor()
@ -62,6 +68,7 @@ class PauseResume:
self.gcode.run_script_from_command( self.gcode.run_script_from_command(
"G92 E%.6f" % (self.captured_epos)) "G92 E%.6f" % (self.captured_epos))
self.captured_position = self.captured_epos = None self.captured_position = self.captured_epos = None
self.pause_command_sent = False
if self.sd_paused: if self.sd_paused:
# Printing from virtual sd, run pause command # Printing from virtual sd, run pause command
self.v_sd.cmd_M24({}) self.v_sd.cmd_M24({})

View File

@ -60,6 +60,9 @@ class VirtualSD:
return {'progress': progress} return {'progress': progress}
def is_active(self): def is_active(self):
return self.work_timer is not None return self.work_timer is not None
def do_pause(self):
if self.work_timer is not None:
self.must_pause_work = True
# G-Code commands # G-Code commands
def cmd_error(self, params): def cmd_error(self, params):
raise self.gcode.error("SD write not supported") raise self.gcode.error("SD write not supported")
@ -116,8 +119,7 @@ class VirtualSD:
self.work_handler, self.reactor.NOW) self.work_handler, self.reactor.NOW)
def cmd_M25(self, params): def cmd_M25(self, params):
# Pause SD print # Pause SD print
if self.work_timer is not None: self.do_pause()
self.must_pause_work = True
def cmd_M26(self, params): def cmd_M26(self, params):
# Set SD position # Set SD position
if self.work_timer is not None: if self.work_timer is not None: