gcode_macro: Support overriding of builtin g-code commands
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
0cfab84e1a
commit
9818055ac3
|
@ -420,6 +420,13 @@
|
||||||
# can be changed at run-time using the SET_GCODE_VARIABLE command
|
# can be changed at run-time using the SET_GCODE_VARIABLE command
|
||||||
# (see docs/Command_Templates.md for details). Variable names may
|
# (see docs/Command_Templates.md for details). Variable names may
|
||||||
# not use upper case characters.
|
# not use upper case characters.
|
||||||
|
#rename_existing:
|
||||||
|
# This option will cause the macro to override an existing G-Code
|
||||||
|
# command, and the existing definition for the command will be
|
||||||
|
# renamed to the name provided here. This can be used to override
|
||||||
|
# builtin G-Code commands. Care should be taken when overriding
|
||||||
|
# commands as that can cause complex and unexpected results. The
|
||||||
|
# default is to not override an existing G-Code command.
|
||||||
|
|
||||||
# Execute a gcode on a set delay.
|
# Execute a gcode on a set delay.
|
||||||
#[delayed_gcode my_delayed_gcode]
|
#[delayed_gcode my_delayed_gcode]
|
||||||
|
|
|
@ -92,11 +92,22 @@ class GCodeMacro:
|
||||||
def __init__(self, config):
|
def __init__(self, config):
|
||||||
name = config.get_name().split()[1]
|
name = config.get_name().split()[1]
|
||||||
self.alias = name.upper()
|
self.alias = name.upper()
|
||||||
printer = config.get_printer()
|
self.printer = printer = config.get_printer()
|
||||||
gcode_macro = printer.try_load_module(config, 'gcode_macro')
|
gcode_macro = printer.try_load_module(config, 'gcode_macro')
|
||||||
self.template = gcode_macro.load_template(config, 'gcode')
|
self.template = gcode_macro.load_template(config, 'gcode')
|
||||||
self.gcode = printer.lookup_object('gcode')
|
self.gcode = printer.lookup_object('gcode')
|
||||||
self.gcode.register_command(self.alias, self.cmd, desc=self.cmd_desc)
|
self.rename_existing = config.get("rename_existing", None)
|
||||||
|
if self.rename_existing is not None:
|
||||||
|
if (self.gcode.is_traditional_gcode(self.alias)
|
||||||
|
!= self.gcode.is_traditional_gcode(self.rename_existing)):
|
||||||
|
raise config.error(
|
||||||
|
"G-Code macro rename of different types ('%s' vs '%s')"
|
||||||
|
% (self.alias, self.rename_existing))
|
||||||
|
printer.register_event_handler("klippy:connect",
|
||||||
|
self.handle_connect)
|
||||||
|
else:
|
||||||
|
self.gcode.register_command(self.alias, self.cmd,
|
||||||
|
desc=self.cmd_desc)
|
||||||
self.gcode.register_mux_command("SET_GCODE_VARIABLE", "MACRO",
|
self.gcode.register_mux_command("SET_GCODE_VARIABLE", "MACRO",
|
||||||
name, self.cmd_SET_GCODE_VARIABLE,
|
name, self.cmd_SET_GCODE_VARIABLE,
|
||||||
desc=self.cmd_SET_GCODE_VARIABLE_help)
|
desc=self.cmd_SET_GCODE_VARIABLE_help)
|
||||||
|
@ -114,6 +125,16 @@ class GCodeMacro:
|
||||||
raise config.error(
|
raise config.error(
|
||||||
"Option '%s' in section '%s' is not a valid literal" % (
|
"Option '%s' in section '%s' is not a valid literal" % (
|
||||||
option, config.get_name()))
|
option, config.get_name()))
|
||||||
|
def handle_connect(self):
|
||||||
|
prev_cmd = self.gcode.register_command(self.alias, None)
|
||||||
|
if prev_cmd is None:
|
||||||
|
raise self.printer.config_error(
|
||||||
|
"Existing command '%s' not found in gcode_macro rename"
|
||||||
|
% (self.alias,))
|
||||||
|
pdesc = "Renamed builtin of '%s'" % (self.alias,)
|
||||||
|
self.gcode.register_command(self.rename_existing, prev_cmd, desc=pdesc)
|
||||||
|
self.gcode.register_command(self.alias, self.cmd, desc=self.cmd_desc)
|
||||||
|
return dict(self.variables)
|
||||||
def get_status(self, eventtime):
|
def get_status(self, eventtime):
|
||||||
return dict(self.variables)
|
return dict(self.variables)
|
||||||
cmd_SET_GCODE_VARIABLE_help = "Set the value of a G-Code macro variable"
|
cmd_SET_GCODE_VARIABLE_help = "Set the value of a G-Code macro variable"
|
||||||
|
|
Loading…
Reference in New Issue