# HG changeset patch # User Goffi # Date 1697636018 -7200 # Node ID 33fd658d9d005f58121451230646b134c27efc9f # Parent 8e5333f1b4307f5b857319e297a3d41c241cfdea cli (base): catch `SystemExit` to do a proper `quit` when `Ctrl-C` is pressed. diff -r 8e5333f1b430 -r 33fd658d9d00 libervia/cli/base.py --- a/libervia/cli/base.py Wed Oct 18 15:33:34 2023 +0200 +++ b/libervia/cli/base.py Wed Oct 18 15:33:38 2023 +0200 @@ -116,7 +116,7 @@ sys.exit(1) self.bridge = bridge_module.AIOBridge() - self._onQuitCallbacks = [] + self._on_quit_callbacks = [] def get_config(self, name, section=C.CONFIG_SECTION, default=None): """Retrieve a setting value from sat.conf""" @@ -301,7 +301,7 @@ @param callback(callback): method to call """ - self._onQuitCallbacks.append((callback, args, kwargs)) + self._on_quit_callbacks.append((callback, args, kwargs)) def get_output_choices(self, output_type): """Return valid output filters for output_type @@ -730,7 +730,10 @@ def _run(self, args=None, namespace=None): self.loop = LiberviaCLILoop() - self.loop.run(self, args, namespace) + try: + self.loop.run(self, args, namespace) + except SystemExit: + self.quit() @classmethod def run(cls): @@ -785,12 +788,13 @@ """ # first the onQuitCallbacks try: - callbacks_list = self._onQuitCallbacks + callbacks_list = self._on_quit_callbacks except AttributeError: pass else: for callback, args, kwargs in callbacks_list: callback(*args, **kwargs) + callbacks_list.clear() self.loop.quit(exit_code) if raise_exc: