aboutsummaryrefslogtreecommitdiffstats
path: root/klippy/extruder.py
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2018-04-03 17:01:10 -0400
committerKevin O'Connor <kevin@koconnor.net>2018-04-04 23:13:53 -0400
commitaed958eb5c32003c7ffcd10d8852082b6d896794 (patch)
tree8fed6212b4170da3fecefca103cbc70ffa4575ce /klippy/extruder.py
parent4eeb43b191e3d928cf817d3be0350711dc05526d (diff)
downloadkutter-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.py16
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,))