aboutsummaryrefslogtreecommitdiffstats
path: root/klippy/extras
diff options
context:
space:
mode:
Diffstat (limited to 'klippy/extras')
-rw-r--r--klippy/extras/board_pins.py43
1 files changed, 25 insertions, 18 deletions
diff --git a/klippy/extras/board_pins.py b/klippy/extras/board_pins.py
index d8388cbd..780a49b6 100644
--- a/klippy/extras/board_pins.py
+++ b/klippy/extras/board_pins.py
@@ -1,29 +1,36 @@
# Support for custom board pin aliases
#
-# Copyright (C) 2019 Kevin O'Connor <kevin@koconnor.net>
+# Copyright (C) 2019-2020 Kevin O'Connor <kevin@koconnor.net>
#
# This file may be distributed under the terms of the GNU GPLv3 license.
class PrinterBoardAliases:
- def __init__(self, config, chip_name):
+ def __init__(self, config):
ppins = config.get_printer().lookup_object('pins')
- pin_resolver = ppins.get_pin_resolver(chip_name)
- aliases = config.get("aliases").strip()
- if aliases.endswith(','):
- aliases = aliases[:-1]
- parts = [a.split('=', 1) for a in aliases.split(',')]
- for pair in parts:
- if len(pair) != 2:
- raise ppins.error("Unable to parse aliases in %s"
- % (config.get_name(),))
- name, value = [s.strip() for s in pair]
- if value.startswith('<') and value.endswith('>'):
- pin_resolver.reserve_pin(name, value)
- else:
- pin_resolver.alias_pin(name, value)
+ mcu_names = [n.strip() for n in config.get('mcu', 'mcu').split(',')]
+ pin_resolvers = [ppins.get_pin_resolver(n) for n in mcu_names]
+ options = ["aliases"] + config.get_prefix_options("aliases_")
+ for opt in options:
+ aliases = config.get(opt, "").strip()
+ if not aliases:
+ continue
+ if aliases.endswith(','):
+ aliases = aliases[:-1]
+ parts = [a.split('=', 1) for a in aliases.split(',')]
+ for pair in parts:
+ if len(pair) != 2:
+ raise ppins.error("Unable to parse aliases in %s"
+ % (config.get_name(),))
+ name, value = [s.strip() for s in pair]
+ if value.startswith('<') and value.endswith('>'):
+ for pin_resolver in pin_resolvers:
+ pin_resolver.reserve_pin(name, value)
+ else:
+ for pin_resolver in pin_resolvers:
+ pin_resolver.alias_pin(name, value)
def load_config(config):
- return PrinterBoardAliases(config, "mcu")
+ return PrinterBoardAliases(config)
def load_config_prefix(config):
- return PrinterBoardAliases(config, config.get_name().split()[1])
+ return PrinterBoardAliases(config)