diff options
author | Kevin O'Connor <kevin@koconnor.net> | 2018-04-03 17:01:10 -0400 |
---|---|---|
committer | Kevin O'Connor <kevin@koconnor.net> | 2018-04-04 23:13:53 -0400 |
commit | aed958eb5c32003c7ffcd10d8852082b6d896794 (patch) | |
tree | 8fed6212b4170da3fecefca103cbc70ffa4575ce /klippy/extruder.py | |
parent | 4eeb43b191e3d928cf817d3be0350711dc05526d (diff) | |
download | kutter-aed958eb5c32003c7ffcd10d8852082b6d896794.tar.gz kutter-aed958eb5c32003c7ffcd10d8852082b6d896794.tar.xz kutter-aed958eb5c32003c7ffcd10d8852082b6d896794.zip |
heater: Add PrinterHeaters class that stores all sensors and heaters
Add a PrinterHeaters class that can stores references to available
temperature sensors and stores references to instantiated heaters.
Add a extras/heater_bed.py file and delay instantiation of the
heater_bed object. This allows the heater.py module to be imported
earlier during the setup phase, and allows the PrinterHeaters class to
be available for registering sensors and heaters.
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
Diffstat (limited to 'klippy/extruder.py')
-rw-r--r-- | klippy/extruder.py | 16 |
1 files changed, 4 insertions, 12 deletions
diff --git a/klippy/extruder.py b/klippy/extruder.py index d4dcb2bc..59d8b36a 100644 --- a/klippy/extruder.py +++ b/klippy/extruder.py @@ -4,7 +4,7 @@ # # This file may be distributed under the terms of the GNU GPLv3 license. import math, logging -import stepper, heater, homing +import stepper, homing EXTRUDE_DIFF_IGNORE = 1.02 @@ -13,10 +13,11 @@ class PrinterExtruder: self.printer = printer self.name = config.get_name() shared_heater = config.get('shared_heater', None) + pheater = printer.lookup_object('heater') if shared_heater is None: - self.heater = heater.PrinterHeater(printer, config) + self.heater = pheater.setup_heater(config) else: - self.heater = get_printer_heater(printer, shared_heater) + self.heater = pheater.lookup_heater(shared_heater) self.stepper = stepper.PrinterStepper(printer, config) self.nozzle_diameter = config.getfloat('nozzle_diameter', above=0.) filament_diameter = config.getfloat( @@ -274,12 +275,3 @@ def get_printer_extruders(printer): break out.append(extruder) return out - -def get_printer_heater(printer, name): - if name == 'heater_bed': - return printer.lookup_object(name) - if name == 'extruder': - name = 'extruder0' - if name.startswith('extruder'): - return printer.lookup_object(name).get_heater() - raise printer.config_error("Unknown heater '%s'" % (name,)) |