aboutsummaryrefslogtreecommitdiffstats
path: root/klippy/klippy.py
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2020-09-16 12:15:19 -0400
committerKevin O'Connor <kevin@koconnor.net>2020-09-16 23:53:45 -0400
commit760a0f8df538ecce87812004ecea73e0db95d99b (patch)
tree4fcebbe13d59f8d7a6a889a68a80a1758cc3cd8b /klippy/klippy.py
parenta3fa11ffd454d6efec414646213eccd3a8525165 (diff)
downloadkutter-760a0f8df538ecce87812004ecea73e0db95d99b.tar.gz
kutter-760a0f8df538ecce87812004ecea73e0db95d99b.tar.xz
kutter-760a0f8df538ecce87812004ecea73e0db95d99b.zip
reactor: Add explicit finalize() method to clean up reactor state
The existence of a __del__() method prevents deallocation on python2 if there are circular references. Replace the __del__() method with a new finalize() call and arrange for it to be called when the main reactor is released. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
Diffstat (limited to 'klippy/klippy.py')
-rw-r--r--klippy/klippy.py8
1 files changed, 5 insertions, 3 deletions
diff --git a/klippy/klippy.py b/klippy/klippy.py
index 3d090886..187b45e5 100644
--- a/klippy/klippy.py
+++ b/klippy/klippy.py
@@ -48,10 +48,10 @@ Printer is shutdown
class Printer:
config_error = configfile.error
command_error = homing.CommandError
- def __init__(self, bglogger, start_args):
+ def __init__(self, main_reactor, bglogger, start_args):
self.bglogger = bglogger
self.start_args = start_args
- self.reactor = reactor.Reactor()
+ self.reactor = main_reactor
self.reactor.register_callback(self._connect)
self.state_message = message_startup
self.in_shutdown_state = False
@@ -312,11 +312,13 @@ def main():
if bglogger is not None:
bglogger.clear_rollover_info()
bglogger.set_rollover_info('versions', versions)
- printer = Printer(bglogger, start_args)
+ main_reactor = reactor.Reactor()
+ printer = Printer(main_reactor, bglogger, start_args)
res = printer.run()
if res in ['exit', 'error_exit']:
break
time.sleep(1.)
+ main_reactor.finalize()
logging.info("Restarting printer")
start_args['start_reason'] = res