aboutsummaryrefslogtreecommitdiffstats
path: root/klippy/extras/homing_heaters.py
blob: e9b37f9930d328e7568afae085b3112c12165463 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
# Heater handling on homing moves
#
# Copyright (C) 2016-2018  Kevin O'Connor <kevin@koconnor.net>
#
# This file may be distributed under the terms of the GNU GPLv3 license.

import logging


class HomingHeaters:
    def __init__(self, config):
        self.printer = config.get_printer()
        self.printer.register_event_handler("klippy:connect", self.handle_connect)
        self.printer.register_event_handler(
            "homing:homing_move_begin", self.handle_homing_move_begin
        )
        self.printer.register_event_handler(
            "homing:homing_move_end", self.handle_homing_move_end
        )
        self.disable_heaters = config.getlist("heaters", None)
        self.flaky_steppers = config.getlist("steppers", None)
        self.pheaters = self.printer.load_object(config, "heaters")
        self.target_save = {}

    def handle_connect(self):
        # heaters to disable
        all_heaters = self.pheaters.get_all_heaters()
        if self.disable_heaters is None:
            self.disable_heaters = all_heaters
        else:
            if not all(x in all_heaters for x in self.disable_heaters):
                raise self.printer.config_error(
                    "One or more of these heaters are unknown: %s"
                    % (self.disable_heaters,)
                )
        # steppers valid?
        kin = self.printer.lookup_object("toolhead").get_kinematics()
        all_steppers = [s.get_name() for s in kin.get_steppers()]
        if self.flaky_steppers is None:
            return
        if not all(x in all_steppers for x in self.flaky_steppers):
            raise self.printer.config_error(
                "One or more of these steppers are unknown: %s" % (self.flaky_steppers,)
            )

    def check_eligible(self, endstops):
        if self.flaky_steppers is None:
            return True
        steppers_being_homed = [
            s.get_name() for es in endstops for s in es.get_steppers()
        ]
        return any(x in self.flaky_steppers for x in steppers_being_homed)

    def handle_homing_move_begin(self, hmove):
        if not self.check_eligible(hmove.get_mcu_endstops()):
            return
        for heater_name in self.disable_heaters:
            heater = self.pheaters.lookup_heater(heater_name)
            self.target_save[heater_name] = heater.get_temp(0)[1]
            heater.set_temp(0.0)

    def handle_homing_move_end(self, hmove):
        if not self.check_eligible(hmove.get_mcu_endstops()):
            return
        for heater_name in self.disable_heaters:
            heater = self.pheaters.lookup_heater(heater_name)
            heater.set_temp(self.target_save[heater_name])


def load_config(config):
    return HomingHeaters(config)