diff --git a/klippy/extras/controller_fan.py b/klippy/extras/controller_fan.py index bc33fa311364..4c5e1034a121 100644 --- a/klippy/extras/controller_fan.py +++ b/klippy/extras/controller_fan.py @@ -7,45 +7,40 @@ PIN_MIN_TIME = 0.100 + class ControllerFan: def __init__(self, config): self.printer = config.get_printer() self.printer.register_event_handler("klippy:ready", self.handle_ready) - self.printer.register_event_handler("klippy:connect", - self.handle_connect) + self.printer.register_event_handler("klippy:connect", self.handle_connect) self.stepper_names = config.getlist("stepper", None) - self.stepper_enable = self.printer.load_object(config, 'stepper_enable') - self.printer.load_object(config, 'heaters') + self.stepper_enable = self.printer.load_object(config, "stepper_enable") + self.printer.load_object(config, "heaters") self.heaters = [] self.fan = fan.Fan(config) - self.fan_speed = config.getfloat('fan_speed', default=1., - minval=0., maxval=1.) + self.fan_speed = config.getfloat( + "fan_speed", default=1.0, minval=0.0, maxval=1.0 + ) self.idle_speed = config.getfloat( - 'idle_speed', default=self.fan_speed, minval=0., maxval=1.) + "idle_speed", default=self.fan_speed, minval=0.0, maxval=1.0 + ) self.idle_timeout = config.getint("idle_timeout", default=30, minval=0) self.heater_names = config.getlist("heater", ("extruder",)) self.last_on = self.idle_timeout - self.last_speed = 0. + self.last_speed = 0.0 # get configured temperature_sensors as # ((str, str), (str, str)) => (("pi", "55"), ("spider", "77")) temperature_sensors_config = config.getlists( - "temperature_sensors", - seps=(':', '\n'), - count=2, - default=[] + "temperature_sensors", seps=(":", "\n"), count=2, default=[] ) # parse given thresholds to floats self.temperature_sensors_config = [ - ( - sensor[0], - float(sensor[1]) - ) for sensor in temperature_sensors_config + (sensor[0], float(sensor[1])) for sensor in temperature_sensors_config ] self.temperature_sensors = dict() self.temperature_sensors_only = config.getboolean( - "temperature_sensors_only", - False + "temperature_sensors_only", False ) if self.temperature_sensors_only and len(self.temperature_sensors_config) <= 0: raise self.printer.config_error( @@ -58,11 +53,11 @@ def handle_connect(self): self.__handle_connect_steppers() self.__handle_connect_temperature_sensors() - def __handle_connect_heaters(): - pheaters = self.printer.lookup_object('heaters') + def __handle_connect_heaters(self): + pheaters = self.printer.lookup_object("heaters") self.heaters = [pheaters.lookup_heater(n) for n in self.heater_names] - def __handle_connect_steppers(): + def __handle_connect_steppers(self): all_steppers = self.stepper_enable.get_steppers() if self.stepper_names is None: self.stepper_names = all_steppers @@ -75,45 +70,45 @@ def __handle_connect_steppers(): % (self.stepper_names, ", ".join(all_steppers)) ) - def __handle_connect_temperature_sensors(): + def __handle_connect_temperature_sensors(self): all_temperature_sensor_module_names = [ - sensor[0] for sensor in self.printer.lookup_objects( - module='temperature_sensor' - ) + sensor[0] + for sensor in self.printer.lookup_objects(module="temperature_sensor") ] all_temperature_sensor_names = [ - sensor.split(' ')[1] for sensor in all_temperature_sensor_module_names + sensor.split(" ")[1] for sensor in all_temperature_sensor_module_names ] for sensor_name, temperature_threshold in self.temperature_sensors_config: actual_configured_sensor = None try: actual_configured_sensor = self.printer.lookup_object( - 'temperature_sensor ' + sensor_name.strip() + "temperature_sensor " + sensor_name.strip() ) except Exception: pass if actual_configured_sensor is None: raise self.printer.config_error( - "temperature_sensor '%s' is unknown, (valid sensors are: %s)" + "temperature_sensor '%s' is unknown, " + "(valid sensors are: %s)" % (sensor_name, ", ".join(all_temperature_sensor_names)) ) self.temperature_sensors[sensor_name] = ( actual_configured_sensor, - temperature_threshold + temperature_threshold, ) def handle_ready(self): reactor = self.printer.get_reactor() - reactor.register_timer(self.callback, reactor.monotonic()+PIN_MIN_TIME) + reactor.register_timer(self.callback, reactor.monotonic() + PIN_MIN_TIME) def get_status(self, eventtime): return self.fan.get_status(eventtime) def callback(self, eventtime): - speed = 0. + speed = 0.0 active = self.__check_fan_active(eventtime) if active: @@ -129,9 +124,9 @@ def callback(self, eventtime): print_time = self.fan.get_mcu().estimated_print_time(curtime) self.fan.set_speed(print_time + PIN_MIN_TIME, speed) - return eventtime + 1. + return eventtime + 1.0 - def __check_fan_active(eventtime): + def __check_fan_active(self, eventtime): for sensor, threshold in self.temperature_sensors.items(): current_temp, _ = sensor.get_temp(eventtime) if current_temp > threshold: @@ -149,5 +144,6 @@ def __check_fan_active(eventtime): if target_temp: return True + def load_config_prefix(config): return ControllerFan(config)