From d9b00acdc665e88d41d96bdba199f5f69c2302d8 Mon Sep 17 00:00:00 2001 From: RyanJenkins Date: Sat, 23 Dec 2017 23:59:02 -0800 Subject: [PATCH 1/3] Return focus to qutebrowser when external editor finishes. --- qutebrowser/browser/commands.py | 1 + 1 file changed, 1 insertion(+) diff --git a/qutebrowser/browser/commands.py b/qutebrowser/browser/commands.py index 92a841d72..a912842f6 100644 --- a/qutebrowser/browser/commands.py +++ b/qutebrowser/browser/commands.py @@ -1639,6 +1639,7 @@ class CommandDispatcher: """ try: elem.set_value(text) + mainwindow.raise_window(objreg.last_focused_window()) except webelem.OrphanedError as e: message.error('Edited element vanished') except webelem.Error as e: From 9cb25e0c76e80b311898fd5aace7c27ac2169bdc Mon Sep 17 00:00:00 2001 From: RyanJenkins Date: Tue, 26 Dec 2017 20:19:39 -0800 Subject: [PATCH 2/3] Raise browser window after editor closes regardless of outcome of inserting text and avoid calling QApplication.instance().alert() in this scenario. --- qutebrowser/browser/commands.py | 3 ++- qutebrowser/mainwindow/mainwindow.py | 6 ++++-- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/qutebrowser/browser/commands.py b/qutebrowser/browser/commands.py index a912842f6..3fffbcfb7 100644 --- a/qutebrowser/browser/commands.py +++ b/qutebrowser/browser/commands.py @@ -1639,12 +1639,13 @@ class CommandDispatcher: """ try: elem.set_value(text) - mainwindow.raise_window(objreg.last_focused_window()) except webelem.OrphanedError as e: message.error('Edited element vanished') except webelem.Error as e: raise cmdexc.CommandError(str(e)) + mainwindow.raise_window(objreg.last_focused_window(), alert=False) + @cmdutils.register(instance='command-dispatcher', maxsplit=0, scope='window') def insert_text(self, text): diff --git a/qutebrowser/mainwindow/mainwindow.py b/qutebrowser/mainwindow/mainwindow.py index 3adce7567..9d288b565 100644 --- a/qutebrowser/mainwindow/mainwindow.py +++ b/qutebrowser/mainwindow/mainwindow.py @@ -94,13 +94,15 @@ def get_window(via_ipc, force_window=False, force_tab=False, return window.win_id -def raise_window(window): +def raise_window(window, alert=False): """Raise the given MainWindow object.""" window.setWindowState(window.windowState() & ~Qt.WindowMinimized) window.setWindowState(window.windowState() | Qt.WindowActive) window.raise_() window.activateWindow() - QApplication.instance().alert(window) + + if alert: + QApplication.instance().alert(window) # WORKAROUND for https://github.com/PyCQA/pylint/issues/1770 From 53575aaeed5a1e8389bbf0980fed757e85c34349 Mon Sep 17 00:00:00 2001 From: RyanJenkins Date: Wed, 27 Dec 2017 12:40:55 -0800 Subject: [PATCH 3/3] Default raise_windows() alert param to True to preserve existing behavior --- qutebrowser/mainwindow/mainwindow.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/qutebrowser/mainwindow/mainwindow.py b/qutebrowser/mainwindow/mainwindow.py index 9d288b565..dff465c41 100644 --- a/qutebrowser/mainwindow/mainwindow.py +++ b/qutebrowser/mainwindow/mainwindow.py @@ -94,7 +94,7 @@ def get_window(via_ipc, force_window=False, force_tab=False, return window.win_id -def raise_window(window, alert=False): +def raise_window(window, alert=True): """Raise the given MainWindow object.""" window.setWindowState(window.windowState() & ~Qt.WindowMinimized) window.setWindowState(window.windowState() | Qt.WindowActive)