aboutsummaryrefslogtreecommitdiffstats
path: root/klippy/heater.py
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2020-04-25 13:06:51 -0400
committerKevin O'Connor <kevin@koconnor.net>2020-04-25 14:26:28 -0400
commitd858498a53fe98ed705595b8639b50b219d6262f (patch)
tree40e1a8e8d9da4f61ad275a67226bd143d2ab0050 /klippy/heater.py
parent44f868a802852317f68886c47255b0fb90fb7ae2 (diff)
downloadkutter-d858498a53fe98ed705595b8639b50b219d6262f.tar.gz
kutter-d858498a53fe98ed705595b8639b50b219d6262f.tar.xz
kutter-d858498a53fe98ed705595b8639b50b219d6262f.zip
heater: Move M105 command handling from gcode.py to heater.py
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
Diffstat (limited to 'klippy/heater.py')
-rw-r--r--klippy/heater.py46
1 files changed, 40 insertions, 6 deletions
diff --git a/klippy/heater.py b/klippy/heater.py
index 5e671a5b..4914c767 100644
--- a/klippy/heater.py
+++ b/klippy/heater.py
@@ -231,12 +231,15 @@ class PrinterHeaters:
self.gcode_id_to_sensor = {}
self.available_heaters = []
self.available_sensors = []
+ self.has_started = False
+ self.printer.register_event_handler("klippy:ready", self._handle_ready)
self.printer.register_event_handler("gcode:request_restart",
self.turn_off_all_heaters)
- # Register TURN_OFF_HEATERS command
+ # Register commands
gcode = self.printer.lookup_object('gcode')
gcode.register_command("TURN_OFF_HEATERS", self.cmd_TURN_OFF_HEATERS,
desc=self.cmd_TURN_OFF_HEATERS_help)
+ gcode.register_command("M105", self.cmd_M105, when_not_ready=True)
def add_sensor_factory(self, sensor_type, sensor_factory):
self.sensor_factories[sensor_type] = sensor_factory
def setup_heater(self, config, gcode_id=None):
@@ -267,8 +270,6 @@ class PrinterHeaters:
raise self.printer.config_error(
"Unknown temperature sensor '%s'" % (sensor_type,))
return self.sensor_factories[sensor_type](config)
- def get_gcode_sensors(self):
- return self.gcode_id_to_sensor.items()
def register_sensor(self, config, psensor, gcode_id=None):
if gcode_id is None:
gcode_id = config.get('gcode_id', None)
@@ -279,15 +280,48 @@ class PrinterHeaters:
"G-Code sensor id %s already registered" % (gcode_id,))
self.gcode_id_to_sensor[gcode_id] = psensor
self.available_sensors.append(config.get_name())
+ def get_status(self, eventtime):
+ return {'available_heaters': self.available_heaters,
+ 'available_sensors': self.available_sensors}
def turn_off_all_heaters(self, print_time=0.):
for heater in self.heaters.values():
heater.set_temp(0.)
cmd_TURN_OFF_HEATERS_help = "Turn off all heaters"
def cmd_TURN_OFF_HEATERS(self, params):
self.turn_off_all_heaters()
- def get_status(self, eventtime):
- return {'available_heaters': self.available_heaters,
- 'available_sensors': self.available_sensors}
+ # G-Code M105 temperature reporting
+ def _handle_ready(self):
+ self.has_started = True
+ def _get_temp(self, eventtime):
+ # Tn:XXX /YYY B:XXX /YYY
+ out = []
+ if self.has_started:
+ for gcode_id, sensor in sorted(self.gcode_id_to_sensor.items()):
+ cur, target = sensor.get_temp(eventtime)
+ out.append("%s:%.1f /%.1f" % (gcode_id, cur, target))
+ if not out:
+ return "T:0"
+ return " ".join(out)
+ def cmd_M105(self, params):
+ # Get Extruder Temperature
+ gcode = self.printer.lookup_object("gcode")
+ reactor = self.printer.get_reactor()
+ msg = self._get_temp(reactor.monotonic())
+ did_ack = gcode.ack(msg)
+ if not did_ack:
+ gcode.respond_raw(msg)
+ def wait_for_temperature(self, heater):
+ # Helper to wait on heater.check_busy() and report M105 temperatures
+ if self.printer.get_start_args().get('debugoutput') is not None:
+ return
+ toolhead = self.printer.lookup_object("toolhead")
+ gcode = self.printer.lookup_object("gcode")
+ reactor = self.printer.get_reactor()
+ eventtime = reactor.monotonic()
+ while not self.printer.is_shutdown() and heater.check_busy(eventtime):
+ print_time = toolhead.get_last_move_time()
+ gcode.respond_raw(self._get_temp(eventtime))
+ eventtime = reactor.pause(eventtime + 1.)
def add_printer_objects(config):
config.get_printer().add_object('heater', PrinterHeaters(config))