aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--klippy/extras/homing_override.py4
-rw-r--r--klippy/extras/safe_z_home.py6
-rw-r--r--klippy/gcode.py3
3 files changed, 7 insertions, 6 deletions
diff --git a/klippy/extras/homing_override.py b/klippy/extras/homing_override.py
index 06b497a4..8a40044c 100644
--- a/klippy/extras/homing_override.py
+++ b/klippy/extras/homing_override.py
@@ -14,12 +14,12 @@ class HomingOverride:
self.template = gcode_macro.load_template(config, 'gcode')
self.in_script = False
self.gcode = self.printer.lookup_object('gcode')
- self.gcode.register_command("G28", None)
+ self.prev_G28 = self.gcode.register_command("G28", None)
self.gcode.register_command("G28", self.cmd_G28)
def cmd_G28(self, params):
if self.in_script:
# Was called recursively - invoke the real G28 command
- self.gcode.cmd_G28(params)
+ self.prev_G28(params)
return
# if no axis is given as parameter we assume the override
diff --git a/klippy/extras/safe_z_home.py b/klippy/extras/safe_z_home.py
index a49f6b9a..0489fab7 100644
--- a/klippy/extras/safe_z_home.py
+++ b/klippy/extras/safe_z_home.py
@@ -21,7 +21,7 @@ class SafeZHoming:
self.speed = config.getfloat('speed', 50.0, above=0.)
self.move_to_previous = config.getboolean('move_to_previous', False)
self.gcode = self.printer.lookup_object('gcode')
- self.gcode.register_command("G28", None)
+ self.prev_G28 = self.gcode.register_command("G28", None)
self.gcode.register_command("G28", self.cmd_G28)
if config.has_section("homing_override"):
@@ -63,7 +63,7 @@ class SafeZHoming:
if need_y:
new_params['Y'] = '0'
if new_params:
- self.gcode.cmd_G28(new_params)
+ self.prev_G28(new_params)
# Home Z axis if necessary
if need_z:
# Move to safe XY homing position
@@ -75,7 +75,7 @@ class SafeZHoming:
toolhead.move(pos, self.speed)
self.gcode.reset_last_position()
# Home Z
- self.gcode.cmd_G28({'Z': '0'})
+ self.prev_G28({'Z': '0'})
# Perform Z Hop again for pressure-based probes
pos = toolhead.get_position()
if self.z_hop:
diff --git a/klippy/gcode.py b/klippy/gcode.py
index b679dc63..3335bfbb 100644
--- a/klippy/gcode.py
+++ b/klippy/gcode.py
@@ -71,11 +71,12 @@ class GCodeParser:
return False
def register_command(self, cmd, func, when_not_ready=False, desc=None):
if func is None:
+ old_cmd = self.ready_gcode_handlers.get(cmd)
if cmd in self.ready_gcode_handlers:
del self.ready_gcode_handlers[cmd]
if cmd in self.base_gcode_handlers:
del self.base_gcode_handlers[cmd]
- return
+ return old_cmd
if cmd in self.ready_gcode_handlers:
raise self.printer.config_error(
"gcode command %s already registered" % (cmd,))