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:
Kevin O'Connor 2019-01-08 09:15:40 -05:00
parent b2d5a8e65b
commit fb7fe282c8
6 changed files with 31 additions and 27 deletions

View File

@ -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):

View File

@ -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)

View File

@ -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")

View File

@ -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)))

View File

@ -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()

View File

@ -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):