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:
parent
c8d7e28a35
commit
3cd1f9676d
|
@ -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({})
|
||||||
|
|
|
@ -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:
|
||||||
|
|
Loading…
Reference in New Issue