URI: 
       tqt main_window: fix threading for run_coroutine_from_thread - electrum - Electrum Bitcoin wallet
  HTML git clone https://git.parazyd.org/electrum
   DIR Log
   DIR Files
   DIR Refs
   DIR Submodules
       ---
   DIR commit a74552f3dd21317133cf4802aa255f80a636b870
   DIR parent a98fd14f8d9b9c1d17fd6c25d58cc4b72a6fd8b4
  HTML Author: SomberNight <somber.night@protonmail.com>
       Date:   Thu, 18 Jun 2020 20:43:34 +0200
       
       qt main_window: fix threading for run_coroutine_from_thread
       
       Diffstat:
         M electrum/gui/qt/main_window.py      |       5 ++++-
         M electrum/submarine_swaps.py         |       3 ---
       
       2 files changed, 4 insertions(+), 4 deletions(-)
       ---
   DIR diff --git a/electrum/gui/qt/main_window.py b/electrum/gui/qt/main_window.py
       t@@ -158,6 +158,7 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
            alias_received_signal = pyqtSignal()
            computing_privkeys_signal = pyqtSignal()
            show_privkeys_signal = pyqtSignal()
       +    show_error_signal = pyqtSignal(str)
        
            def __init__(self, gui_object: 'ElectrumGui', wallet: Abstract_Wallet):
                QMainWindow.__init__(self)
       t@@ -250,6 +251,7 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
        
                self.payment_request_ok_signal.connect(self.payment_request_ok)
                self.payment_request_error_signal.connect(self.payment_request_error)
       +        self.show_error_signal.connect(self.show_error)
                self.history_list.setFocus(True)
        
                # network callbacks
       t@@ -307,7 +309,8 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
                        if on_result:
                            on_result(r)
                    except Exception as e:
       -                self.show_error(str(e))
       +                self.logger.exception("exception in coro scheduled via window.wallet")
       +                self.show_error_signal.emit(str(e))
                self.wallet.thread.add(task)
        
            def on_fx_history(self):
   DIR diff --git a/electrum/submarine_swaps.py b/electrum/submarine_swaps.py
       t@@ -183,7 +183,6 @@ class SwapManager(Logger):
                callback = lambda: self._claim_swap(swap)
                self.lnwatcher.add_callback(swap.lockup_address, callback)
        
       -    @log_exceptions
            async def normal_swap(self, lightning_amount: int, expected_onchain_amount: int,
                                  password, *, tx: PartialTransaction = None) -> str:
                """send on-chain BTC, receive on Lightning"""
       t@@ -264,7 +263,6 @@ class SwapManager(Logger):
                await self.network.broadcast_transaction(tx)
                return tx.txid()
        
       -    @log_exceptions
            async def reverse_swap(self, amount_sat: int, expected_amount: int) -> bool:
                """send on Lightning, receive on-chain"""
                privkey = os.urandom(32)
       t@@ -354,7 +352,6 @@ class SwapManager(Logger):
                success, log = await self.lnworker._pay(invoice, attempts=10)
                return success
        
       -    @log_exceptions
            async def get_pairs(self) -> None:
                response = await self.network._send_http_on_proxy(
                    'get',