Browse Source

daemon.run_gui: make sure to exit process on exception

previously, if GUI-related imports raised, the GUI would not start
but the process would not exit (e.g. asyncio event loop would go on)

Traceback (most recent call last):
  File "...\electrum\electrum\daemon.py", line 517, in run_gui
    gui = __import__('electrum.gui.' + gui_name, fromlist=['electrum'])
  File "...\electrum\electrum\gui\qt\__init__.py", line 39, in <module>
    from PyQt5.QtGui import QGuiApplication
ImportError: DLL load failed while importing QtGui: The specified module could not be found.
hard-fail-on-bad-server-string
SomberNight 5 years ago
parent
commit
3d42fca86e
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 6
      electrum/daemon.py
  2. 5
      run_electrum

6
electrum/daemon.py

@ -513,11 +513,13 @@ class Daemon(Logger):
if gui_name in ['lite', 'classic']: if gui_name in ['lite', 'classic']:
gui_name = 'qt' gui_name = 'qt'
self.logger.info(f'launching GUI: {gui_name}') self.logger.info(f'launching GUI: {gui_name}')
try:
gui = __import__('electrum.gui.' + gui_name, fromlist=['electrum']) gui = __import__('electrum.gui.' + gui_name, fromlist=['electrum'])
self.gui_object = gui.ElectrumGui(config, self, plugins) self.gui_object = gui.ElectrumGui(config, self, plugins)
try:
self.gui_object.main() self.gui_object.main()
except BaseException as e: except BaseException as e:
self.logger.exception('') self.logger.error(f'GUI raised exception: {repr(e)}. shutting down.')
raise
finally:
# app will exit now # app will exit now
self.on_stop() self.on_stop()

5
run_electrum

@ -370,7 +370,12 @@ if __name__ == '__main__':
if fd is not None: if fd is not None:
plugins = init_plugins(config, config.get('gui', 'qt')) plugins = init_plugins(config, config.get('gui', 'qt'))
d = daemon.Daemon(config, fd) d = daemon.Daemon(config, fd)
try:
d.run_gui(config, plugins) d.run_gui(config, plugins)
except BaseException as e:
_logger.exception('daemon.run_gui errored')
sys_exit(1)
else:
sys_exit(0) sys_exit(0)
else: else:
result = daemon.request(config, 'gui', (config_options,)) result = daemon.request(config, 'gui', (config_options,))

Loading…
Cancel
Save