stepper_enable: Use new GCodeCommand wrappers

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2020-04-24 22:53:48 -04:00
parent a79096efdf
commit 33c6667881
1 changed files with 21 additions and 21 deletions

View File

@ -74,12 +74,12 @@ class PrinterStepperEnable:
self.printer.register_event_handler("gcode:request_restart", self.printer.register_event_handler("gcode:request_restart",
self._handle_request_restart) self._handle_request_restart)
# Register M18/M84 commands # Register M18/M84 commands
self.gcode = self.printer.lookup_object('gcode') gcode = self.printer.lookup_object('gcode')
self.gcode.register_command("M18", self.cmd_M18) gcode.register_command("M18", self.cmd_M18)
self.gcode.register_command("M84", self.cmd_M18) gcode.register_command("M84", self.cmd_M18)
self.gcode.register_command("SET_STEPPER_ENABLE", gcode.register_command("SET_STEPPER_ENABLE",
self.cmd_SET_STEPPER_ENABLE, self.cmd_SET_STEPPER_ENABLE,
desc = self.cmd_SET_STEPPER_ENABLE_help) desc=self.cmd_SET_STEPPER_ENABLE_help)
def register_stepper(self, stepper, pin): def register_stepper(self, stepper, pin):
name = stepper.get_name() name = stepper.get_name()
self.enable_lines[name] = EnableTracking(self.printer, stepper, pin) self.enable_lines[name] = EnableTracking(self.printer, stepper, pin)
@ -92,32 +92,32 @@ class PrinterStepperEnable:
self.printer.send_event("stepper_enable:motor_off", print_time) self.printer.send_event("stepper_enable:motor_off", print_time)
toolhead.dwell(DISABLE_STALL_TIME) toolhead.dwell(DISABLE_STALL_TIME)
logging.debug('; Max time of %f', print_time) logging.debug('; Max time of %f', print_time)
def motor_debug_enable(self, stepper=None, enable=1): def motor_debug_enable(self, stepper, enable):
toolhead = self.printer.lookup_object('toolhead') toolhead = self.printer.lookup_object('toolhead')
toolhead.dwell(DISABLE_STALL_TIME) toolhead.dwell(DISABLE_STALL_TIME)
print_time = toolhead.get_last_move_time() print_time = toolhead.get_last_move_time()
if stepper in self.enable_lines: el = self.enable_lines[stepper]
el = self.enable_lines.get(stepper, "") if enable:
if enable: el.motor_enable(print_time)
el.motor_enable(print_time) logging.info("%s has been manually enabled", stepper)
logging.info("%s has been manually enabled", stepper)
else:
el.motor_disable(print_time)
logging.info("%s has been manually disabled", stepper)
else: else:
self.gcode.respond_info('SET_STEPPER_ENABLE: Invalid stepper "%s"' el.motor_disable(print_time)
% (stepper)) logging.info("%s has been manually disabled", stepper)
toolhead.dwell(DISABLE_STALL_TIME) toolhead.dwell(DISABLE_STALL_TIME)
logging.debug('; Max time of %f', print_time) logging.debug('; Max time of %f', print_time)
def _handle_request_restart(self, print_time): def _handle_request_restart(self, print_time):
self.motor_off() self.motor_off()
def cmd_M18(self, params): def cmd_M18(self, gcmd):
# Turn off motors # Turn off motors
self.motor_off() self.motor_off()
cmd_SET_STEPPER_ENABLE_help = "Enable/disable individual stepper by name" cmd_SET_STEPPER_ENABLE_help = "Enable/disable individual stepper by name"
def cmd_SET_STEPPER_ENABLE(self, params): def cmd_SET_STEPPER_ENABLE(self, gcmd):
stepper_name = self.gcode.get_str('STEPPER', params, None) stepper_name = gcmd.get('STEPPER', None)
stepper_enable = self.gcode.get_int('ENABLE', params, 1) if stepper_name not in self.enable_lines:
gcmd.respond_info('SET_STEPPER_ENABLE: Invalid stepper "%s"'
% (stepper_name,))
return
stepper_enable = gcmd.get_int('ENABLE', 1)
self.motor_debug_enable(stepper_name, stepper_enable) self.motor_debug_enable(stepper_name, stepper_enable)
def lookup_enable(self, name): def lookup_enable(self, name):
if name not in self.enable_lines: if name not in self.enable_lines: