Prompt when closing a pinned tab via the mouse

Closes #2761
This commit is contained in:
Jay Kamat 2017-06-27 19:02:41 -07:00
parent 5ec94f96fd
commit 4d1dbe11e8
No known key found for this signature in database
GPG Key ID: 5D2E399600F4F7B5
2 changed files with 7 additions and 4 deletions

View File

@ -227,7 +227,8 @@ class CommandDispatcher:
self._tabbed_browser.close_tab(tab) self._tabbed_browser.close_tab(tab)
tabbar.setSelectionBehaviorOnRemove(old_selection_behavior) tabbar.setSelectionBehaviorOnRemove(old_selection_behavior)
def _tab_close_prompt_if_pinned(self, tab, force, yes_action): @staticmethod
def tab_close_prompt_if_pinned(tab, force, yes_action):
"""Helper method for tab_close. """Helper method for tab_close.
If tab is pinned, prompt. If everything is good, run yes_action. If tab is pinned, prompt. If everything is good, run yes_action.
@ -260,7 +261,7 @@ class CommandDispatcher:
close = functools.partial(self._tab_close, tab, prev, close = functools.partial(self._tab_close, tab, prev,
next_, opposite) next_, opposite)
self._tab_close_prompt_if_pinned(tab, force, close) CommandDispatcher.tab_close_prompt_if_pinned(tab, force, close)
@cmdutils.register(instance='command-dispatcher', scope='window', @cmdutils.register(instance='command-dispatcher', scope='window',
name='tab-pin') name='tab-pin')
@ -920,7 +921,7 @@ class CommandDispatcher:
if not force: if not force:
for i, tab in enumerate(self._tabbed_browser.widgets()): for i, tab in enumerate(self._tabbed_browser.widgets()):
if _to_close(i) and tab.data.pinned: if _to_close(i) and tab.data.pinned:
self._tab_close_prompt_if_pinned( CommandDispatcher.tab_close_prompt_if_pinned(
tab, force, tab, force,
lambda: self.tab_only( lambda: self.tab_only(
prev=prev, next_=next_, force=True)) prev=prev, next_=next_, force=True))

View File

@ -26,6 +26,7 @@ from PyQt5.QtWidgets import QSizePolicy
from PyQt5.QtCore import pyqtSignal, pyqtSlot, QTimer, QUrl, QSize from PyQt5.QtCore import pyqtSignal, pyqtSlot, QTimer, QUrl, QSize
from PyQt5.QtGui import QIcon from PyQt5.QtGui import QIcon
from qutebrowser.browser.commands import CommandDispatcher
from qutebrowser.config import config from qutebrowser.config import config
from qutebrowser.keyinput import modeman from qutebrowser.keyinput import modeman
from qutebrowser.mainwindow import tabwidget from qutebrowser.mainwindow import tabwidget
@ -366,7 +367,8 @@ class TabbedBrowser(tabwidget.TabWidget):
log.webview.debug("Got invalid tab {} for index {}!".format( log.webview.debug("Got invalid tab {} for index {}!".format(
tab, idx)) tab, idx))
return return
self.close_tab(tab) CommandDispatcher.tab_close_prompt_if_pinned(
tab, False, lambda: self.close_tab(tab))
@pyqtSlot(browsertab.AbstractTab) @pyqtSlot(browsertab.AbstractTab)
def on_window_close_requested(self, widget): def on_window_close_requested(self, widget):