probe: Use gcode_macro style templates on activate/deactivate_gcode

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2019-04-02 22:04:22 -04:00
parent 486c07c190
commit 7d246e2624
1 changed files with 14 additions and 8 deletions

View File

@ -177,9 +177,13 @@ class PrinterProbe:
class ProbeEndstopWrapper: class ProbeEndstopWrapper:
def __init__(self, config): def __init__(self, config):
self.printer = config.get_printer() self.printer = config.get_printer()
self.gcode = self.printer.lookup_object('gcode')
self.position_endstop = config.getfloat('z_offset') self.position_endstop = config.getfloat('z_offset')
self.activate_gcode = config.get('activate_gcode', None) gcode_macro = self.printer.try_load_module(config, 'gcode_macro')
self.deactivate_gcode = config.get('deactivate_gcode', None) self.activate_gcode = gcode_macro.load_template(
config, 'activate_gcode')
self.deactivate_gcode = gcode_macro.load_template(
config, 'deactivate_gcode')
# Create an "endstop" object to handle the probe pin # Create an "endstop" object to handle the probe pin
ppins = self.printer.lookup_object('pins') ppins = self.printer.lookup_object('pins')
pin = config.get('pin') pin = config.get('pin')
@ -201,14 +205,16 @@ class ProbeEndstopWrapper:
for stepper in kin.get_steppers('Z'): for stepper in kin.get_steppers('Z'):
stepper.add_to_endstop(self) stepper.add_to_endstop(self)
def home_prepare(self): def home_prepare(self):
if self.activate_gcode is not None: try:
gcode = self.printer.lookup_object('gcode') self.activate_gcode.run_gcode_from_command()
gcode.run_script_from_command(self.activate_gcode) except self.gcode.error as e:
raise homing.EndstopError(str(e))
self.mcu_endstop.home_prepare() self.mcu_endstop.home_prepare()
def home_finalize(self): def home_finalize(self):
if self.deactivate_gcode is not None: try:
gcode = self.printer.lookup_object('gcode') self.deactivate_gcode.run_gcode_from_command()
gcode.run_script_from_command(self.deactivate_gcode) except self.gcode.error as e:
raise homing.EndstopError(str(e))
self.mcu_endstop.home_finalize() self.mcu_endstop.home_finalize()
def get_position_endstop(self): def get_position_endstop(self):
return self.position_endstop return self.position_endstop