aboutsummaryrefslogtreecommitdiffstats
path: root/klippy/extras
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2020-04-25 12:09:03 -0400
committerKevin O'Connor <kevin@koconnor.net>2020-04-25 12:11:49 -0400
commit86a99cf38ed9c041a332505e413805e582a361db (patch)
tree2516aa0817020bd8d03f5722482ac0148061a45e /klippy/extras
parentc590bf76430a1b14a1f9b5ad0c37840291d7b8a9 (diff)
downloadkutter-86a99cf38ed9c041a332505e413805e582a361db.tar.gz
kutter-86a99cf38ed9c041a332505e413805e582a361db.tar.xz
kutter-86a99cf38ed9c041a332505e413805e582a361db.zip
gcode_button: Simplify script execution
It's no longer necessary to queue gcode scripts - gcode.run_script() now does that automatically. Also, make release_gcode config optional. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
Diffstat (limited to 'klippy/extras')
-rw-r--r--klippy/extras/gcode_button.py34
1 files changed, 9 insertions, 25 deletions
diff --git a/klippy/extras/gcode_button.py b/klippy/extras/gcode_button.py
index 757d8f7a..bb2bb458 100644
--- a/klippy/extras/gcode_button.py
+++ b/klippy/extras/gcode_button.py
@@ -11,51 +11,35 @@ class GCodeButton:
self.name = config.get_name().split(' ')[-1]
self.pin = config.get('pin')
self.last_state = 0
- self.template_queue = []
buttons = self.printer.try_load_module(config, "buttons")
buttons.register_buttons([self.pin], self.button_callback)
gcode_macro = self.printer.try_load_module(config, 'gcode_macro')
self.press_template = gcode_macro.load_template(config, 'press_gcode')
- self.release_template = gcode_macro.load_template(
- config, 'release_gcode')
+ self.release_template = gcode_macro.load_template(config,
+ 'release_gcode', '')
self.gcode = self.printer.lookup_object('gcode')
self.gcode.register_mux_command("QUERY_BUTTON", "BUTTON", self.name,
self.cmd_QUERY_BUTTON,
desc=self.cmd_QUERY_BUTTON_help)
cmd_QUERY_BUTTON_help = "Report on the state of a button"
-
def cmd_QUERY_BUTTON(self, params):
self.gcode.respond_info(self.name + ": " + self.get_status()['state'])
def button_callback(self, eventtime, state):
self.last_state = state
- if state and bool(self.press_template):
- self.queue_template(self.press_template)
- if (not state) and bool(self.release_template):
- self.queue_template(self.release_template)
+ template = self.press_template
+ if not state:
+ template = self.release_template
+ try:
+ self.gcode.run_script(template.render())
+ except:
+ logging.exception("Script running error")
def get_status(self, eventtime=None):
if self.last_state:
return {'state': "PRESSED"}
return {'state': "RELEASED"}
- def queue_template(self, template):
- if template is None:
- return
- if not self.template_queue:
- reactor = self.printer.get_reactor()
- reactor.register_callback(self.dispatch_templates)
- self.template_queue.append(template)
-
- def dispatch_templates(self, eventtime):
- while self.template_queue:
- template = self.template_queue[0]
- try:
- self.gcode.run_script(template.render())
- except Exception:
- logging.exception("Script running error")
- self.template_queue.pop(0)
-
def load_config_prefix(config):
return GCodeButton(config)