klippy: Convert printer_state("shutdown") to an event handler
Convert all users of the printer_state("shutdown") handler to register a "klippy:shutdown" event handler instead. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
b2d5a8e65b
commit
fb7fe282c8
|
@ -13,6 +13,8 @@ for the parameters that control this check.
|
||||||
class HeaterCheck:
|
class HeaterCheck:
|
||||||
def __init__(self, config):
|
def __init__(self, config):
|
||||||
self.printer = config.get_printer()
|
self.printer = config.get_printer()
|
||||||
|
self.printer.register_event_handler("klippy:shutdown",
|
||||||
|
self.handle_shutdown)
|
||||||
self.heater_name = config.get_name().split()[1]
|
self.heater_name = config.get_name().split()[1]
|
||||||
self.heater = None
|
self.heater = None
|
||||||
self.hysteresis = config.getfloat('hysteresis', 5., minval=0.)
|
self.hysteresis = config.getfloat('hysteresis', 5., minval=0.)
|
||||||
|
@ -38,7 +40,8 @@ class HeaterCheck:
|
||||||
reactor = self.printer.get_reactor()
|
reactor = self.printer.get_reactor()
|
||||||
self.check_timer = reactor.register_timer(self.check_event,
|
self.check_timer = reactor.register_timer(self.check_event,
|
||||||
reactor.NOW)
|
reactor.NOW)
|
||||||
elif state == 'shutdown' and self.check_timer is not None:
|
def handle_shutdown(self):
|
||||||
|
if self.check_timer is not None:
|
||||||
reactor = self.printer.get_reactor()
|
reactor = self.printer.get_reactor()
|
||||||
reactor.update_timer(self.check_timer, reactor.NEVER)
|
reactor.update_timer(self.check_timer, reactor.NEVER)
|
||||||
def check_event(self, eventtime):
|
def check_event(self, eventtime):
|
||||||
|
|
|
@ -8,6 +8,7 @@ import os, logging
|
||||||
class VirtualSD:
|
class VirtualSD:
|
||||||
def __init__(self, config):
|
def __init__(self, config):
|
||||||
printer = config.get_printer()
|
printer = config.get_printer()
|
||||||
|
printer.register_event_handler("klippy:shutdown", self.handle_shutdown)
|
||||||
# sdcard state
|
# sdcard state
|
||||||
sd = config.get('path')
|
sd = config.get('path')
|
||||||
self.sdcard_dirname = os.path.normpath(os.path.expanduser(sd))
|
self.sdcard_dirname = os.path.normpath(os.path.expanduser(sd))
|
||||||
|
@ -24,8 +25,8 @@ class VirtualSD:
|
||||||
self.gcode.register_command(cmd, getattr(self, 'cmd_' + cmd))
|
self.gcode.register_command(cmd, getattr(self, 'cmd_' + cmd))
|
||||||
for cmd in ['M28', 'M29', 'M30']:
|
for cmd in ['M28', 'M29', 'M30']:
|
||||||
self.gcode.register_command(cmd, self.cmd_error)
|
self.gcode.register_command(cmd, self.cmd_error)
|
||||||
def printer_state(self, state):
|
def handle_shutdown(self):
|
||||||
if state == 'shutdown' and self.work_timer is not None:
|
if self.work_timer is not None:
|
||||||
self.must_pause_work = True
|
self.must_pause_work = True
|
||||||
try:
|
try:
|
||||||
readpos = max(self.file_position - 1024, 0)
|
readpos = max(self.file_position - 1024, 0)
|
||||||
|
|
|
@ -16,6 +16,7 @@ class GCodeParser:
|
||||||
def __init__(self, printer, fd):
|
def __init__(self, printer, fd):
|
||||||
self.printer = printer
|
self.printer = printer
|
||||||
self.fd = fd
|
self.fd = fd
|
||||||
|
printer.register_event_handler("klippy:shutdown", self.handle_shutdown)
|
||||||
# Input handling
|
# Input handling
|
||||||
self.reactor = printer.get_reactor()
|
self.reactor = printer.get_reactor()
|
||||||
self.is_processing_data = False
|
self.is_processing_data = False
|
||||||
|
@ -112,8 +113,7 @@ class GCodeParser:
|
||||||
'homing_ypos': self.homing_position[1],
|
'homing_ypos': self.homing_position[1],
|
||||||
'homing_zpos': self.homing_position[2]
|
'homing_zpos': self.homing_position[2]
|
||||||
}
|
}
|
||||||
def printer_state(self, state):
|
def handle_shutdown(self):
|
||||||
if state == 'shutdown':
|
|
||||||
if not self.is_printer_ready:
|
if not self.is_printer_ready:
|
||||||
return
|
return
|
||||||
self.is_printer_ready = False
|
self.is_printer_ready = False
|
||||||
|
@ -122,7 +122,7 @@ class GCodeParser:
|
||||||
if self.is_fileinput:
|
if self.is_fileinput:
|
||||||
self.printer.request_exit('error_exit')
|
self.printer.request_exit('error_exit')
|
||||||
self._respond_state("Shutdown")
|
self._respond_state("Shutdown")
|
||||||
return
|
def printer_state(self, state):
|
||||||
if state != 'ready':
|
if state != 'ready':
|
||||||
if state == 'disconnect':
|
if state == 'disconnect':
|
||||||
self._respond_state("Disconnect")
|
self._respond_state("Disconnect")
|
||||||
|
|
|
@ -51,14 +51,14 @@ class Printer:
|
||||||
self.bglogger = bglogger
|
self.bglogger = bglogger
|
||||||
self.start_args = start_args
|
self.start_args = start_args
|
||||||
self.reactor = reactor.Reactor()
|
self.reactor = reactor.Reactor()
|
||||||
gc = gcode.GCodeParser(self, input_fd)
|
|
||||||
self.objects = collections.OrderedDict({'gcode': gc})
|
|
||||||
self.reactor.register_callback(self._connect)
|
self.reactor.register_callback(self._connect)
|
||||||
self.state_message = message_startup
|
self.state_message = message_startup
|
||||||
self.is_shutdown = False
|
self.is_shutdown = False
|
||||||
self.run_result = None
|
self.run_result = None
|
||||||
self.state_cb = [gc.printer_state]
|
|
||||||
self.event_handlers = {}
|
self.event_handlers = {}
|
||||||
|
gc = gcode.GCodeParser(self, input_fd)
|
||||||
|
self.objects = collections.OrderedDict({'gcode': gc})
|
||||||
|
self.state_cb = [gc.printer_state]
|
||||||
def get_start_args(self):
|
def get_start_args(self):
|
||||||
return self.start_args
|
return self.start_args
|
||||||
def get_reactor(self):
|
def get_reactor(self):
|
||||||
|
@ -183,8 +183,11 @@ class Printer:
|
||||||
return
|
return
|
||||||
self.is_shutdown = True
|
self.is_shutdown = True
|
||||||
self._set_state("%s%s" % (msg, message_shutdown))
|
self._set_state("%s%s" % (msg, message_shutdown))
|
||||||
for cb in self.state_cb:
|
for cb in self.event_handlers.get("klippy:shutdown", []):
|
||||||
cb('shutdown')
|
try:
|
||||||
|
cb()
|
||||||
|
except:
|
||||||
|
logging.exception("Exception during shutdown handler")
|
||||||
def invoke_async_shutdown(self, msg):
|
def invoke_async_shutdown(self, msg):
|
||||||
self.reactor.register_async_callback(
|
self.reactor.register_async_callback(
|
||||||
(lambda e: self.invoke_shutdown(msg)))
|
(lambda e: self.invoke_shutdown(msg)))
|
||||||
|
|
|
@ -422,6 +422,7 @@ class MCU:
|
||||||
self._name = config.get_name()
|
self._name = config.get_name()
|
||||||
if self._name.startswith('mcu '):
|
if self._name.startswith('mcu '):
|
||||||
self._name = self._name[4:]
|
self._name = self._name[4:]
|
||||||
|
self._printer.register_event_handler("klippy:shutdown", self._shutdown)
|
||||||
# Serial port
|
# Serial port
|
||||||
self._serialport = config.get('serial', '/dev/ttyS0')
|
self._serialport = config.get('serial', '/dev/ttyS0')
|
||||||
baud = 0
|
baud = 0
|
||||||
|
@ -769,8 +770,6 @@ class MCU:
|
||||||
self._connect()
|
self._connect()
|
||||||
elif state == 'disconnect':
|
elif state == 'disconnect':
|
||||||
self._disconnect()
|
self._disconnect()
|
||||||
elif state == 'shutdown':
|
|
||||||
self._shutdown()
|
|
||||||
def __del__(self):
|
def __del__(self):
|
||||||
self._disconnect()
|
self._disconnect()
|
||||||
|
|
||||||
|
|
|
@ -205,6 +205,8 @@ class ToolHead:
|
||||||
self.mcu = self.all_mcus[0]
|
self.mcu = self.all_mcus[0]
|
||||||
self.move_queue = MoveQueue()
|
self.move_queue = MoveQueue()
|
||||||
self.commanded_pos = [0., 0., 0., 0.]
|
self.commanded_pos = [0., 0., 0., 0.]
|
||||||
|
self.printer.register_event_handler("klippy:shutdown",
|
||||||
|
self._handle_shutdown)
|
||||||
# Velocity and acceleration control
|
# Velocity and acceleration control
|
||||||
self.max_velocity = config.getfloat('max_velocity', above=0.)
|
self.max_velocity = config.getfloat('max_velocity', above=0.)
|
||||||
self.max_accel = config.getfloat('max_accel', above=0.)
|
self.max_accel = config.getfloat('max_accel', above=0.)
|
||||||
|
@ -412,13 +414,9 @@ class ToolHead:
|
||||||
return { 'status': status, 'print_time': print_time,
|
return { 'status': status, 'print_time': print_time,
|
||||||
'estimated_print_time': estimated_print_time,
|
'estimated_print_time': estimated_print_time,
|
||||||
'printing_time': print_time - last_print_start_time }
|
'printing_time': print_time - last_print_start_time }
|
||||||
def printer_state(self, state):
|
def _handle_shutdown(self):
|
||||||
if state == 'shutdown':
|
|
||||||
try:
|
|
||||||
self.move_queue.reset()
|
self.move_queue.reset()
|
||||||
self.reset_print_time()
|
self.reset_print_time()
|
||||||
except:
|
|
||||||
logging.exception("Exception in toolhead shutdown")
|
|
||||||
def get_kinematics(self):
|
def get_kinematics(self):
|
||||||
return self.kin
|
return self.kin
|
||||||
def get_max_velocity(self):
|
def get_max_velocity(self):
|
||||||
|
|
Loading…
Reference in New Issue