Browse Source

wallet: (fix) synchronizer would also resub closed wallets...

network cb was not removed, so Synchronizer and the wallet itself was
kept in memory; and Synchronizer kept working
regtest_lnd
SomberNight 6 years ago
parent
commit
e415c0d930
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 2
      electrum/gui/qt/__init__.py
  2. 6
      electrum/util.py

2
electrum/gui/qt/__init__.py

@ -296,7 +296,7 @@ class ElectrumGui(Logger):
self.daemon.add_wallet(wallet) self.daemon.add_wallet(wallet)
return wallet return wallet
def close_window(self, window): def close_window(self, window: ElectrumWindow):
if window in self.windows: if window in self.windows:
self.windows.remove(window) self.windows.remove(window)
self.build_tray_menu() self.build_tray_menu()

6
electrum/util.py

@ -1003,6 +1003,10 @@ class NetworkJobOnDefaultServer(Logger):
raise NotImplementedError() # implemented by subclasses raise NotImplementedError() # implemented by subclasses
async def stop(self): async def stop(self):
self.network.unregister_callback(self._restart)
await self._stop()
async def _stop(self):
await self.group.cancel_remaining() await self.group.cancel_remaining()
@log_exceptions @log_exceptions
@ -1012,7 +1016,7 @@ class NetworkJobOnDefaultServer(Logger):
return # we should get called again soon return # we should get called again soon
async with self._restart_lock: async with self._restart_lock:
await self.stop() await self._stop()
self._reset() self._reset()
await self._start(interface) await self._start(interface)

Loading…
Cancel
Save