Merge branch 'rcorre-completion-item-focus'

This commit is contained in:
Florian Bruhin 2016-08-08 15:23:08 +02:00
commit 8187a334f7
5 changed files with 30 additions and 43 deletions

View File

@ -57,6 +57,8 @@ Removed
- The `:yank-selected` command got merged into `:yank` as `:yank selection` - The `:yank-selected` command got merged into `:yank` as `:yank selection`
and thus removed. and thus removed.
- The `:completion-item-prev` and `:completion-item-next` commands got merged
into a new `:completion-focus {prev,next}` command and thus removed.
v0.8.3 (unreleased) v0.8.3 (unreleased)
------------------- -------------------

View File

@ -914,8 +914,7 @@ How many steps to zoom out.
|<<command-history-next,command-history-next>>|Go forward in the commandline history. |<<command-history-next,command-history-next>>|Go forward in the commandline history.
|<<command-history-prev,command-history-prev>>|Go back in the commandline history. |<<command-history-prev,command-history-prev>>|Go back in the commandline history.
|<<completion-item-del,completion-item-del>>|Delete the current completion item. |<<completion-item-del,completion-item-del>>|Delete the current completion item.
|<<completion-item-next,completion-item-next>>|Select the next completion item. |<<completion-item-focus,completion-item-focus>>|Shift the focus of the completion menu to another item.
|<<completion-item-prev,completion-item-prev>>|Select the previous completion item.
|<<drop-selection,drop-selection>>|Drop selection and keep selection mode enabled. |<<drop-selection,drop-selection>>|Drop selection and keep selection mode enabled.
|<<enter-mode,enter-mode>>|Enter a key mode. |<<enter-mode,enter-mode>>|Enter a key mode.
|<<follow-hint,follow-hint>>|Follow a hint. |<<follow-hint,follow-hint>>|Follow a hint.
@ -991,13 +990,14 @@ Go back in the commandline history.
=== completion-item-del === completion-item-del
Delete the current completion item. Delete the current completion item.
[[completion-item-next]] [[completion-item-focus]]
=== completion-item-next === completion-item-focus
Select the next completion item. Syntax: +:completion-item-focus 'which'+
[[completion-item-prev]] Shift the focus of the completion menu to another item.
=== completion-item-prev
Select the previous completion item. ==== positional arguments
* +'which'+: 'next' or 'prev'
[[drop-selection]] [[drop-selection]]
=== drop-selection === drop-selection

View File

@ -181,16 +181,14 @@ class CompletionView(QTreeView):
# Item is a real item, not a category header -> success # Item is a real item, not a category header -> success
return idx return idx
def _next_prev_item(self, prev): @cmdutils.register(instance='completion', hide=True,
"""Handle a tab press for the CompletionView. modes=[usertypes.KeyMode.command], scope='window')
@cmdutils.argument('which', choices=['next', 'prev'])
Select the previous/next item and write the new text to the def completion_item_focus(self, which):
statusbar. """Shift the focus of the completion menu to another item.
Helper for completion_item_next and completion_item_prev.
Args: Args:
prev: True for prev item, False for next one. which: 'next' or 'prev'
""" """
# selmodel can be None if 'show' and 'auto-open' are set to False # selmodel can be None if 'show' and 'auto-open' are set to False
# https://github.com/The-Compiler/qutebrowser/issues/1731 # https://github.com/The-Compiler/qutebrowser/issues/1731
@ -198,7 +196,7 @@ class CompletionView(QTreeView):
if selmodel is None: if selmodel is None:
return return
idx = self._next_idx(prev) idx = self._next_idx(which == 'prev')
if not idx.isValid(): if not idx.isValid():
return return
@ -278,18 +276,6 @@ class CompletionView(QTreeView):
scrollbar.setValue(scrollbar.minimum()) scrollbar.setValue(scrollbar.minimum())
super().showEvent(e) super().showEvent(e)
@cmdutils.register(instance='completion', hide=True,
modes=[usertypes.KeyMode.command], scope='window')
def completion_item_prev(self):
"""Select the previous completion item."""
self._next_prev_item(True)
@cmdutils.register(instance='completion', hide=True,
modes=[usertypes.KeyMode.command], scope='window')
def completion_item_next(self):
"""Select the next completion item."""
self._next_prev_item(False)
@cmdutils.register(instance='completion', hide=True, @cmdutils.register(instance='completion', hide=True,
modes=[usertypes.KeyMode.command], scope='window') modes=[usertypes.KeyMode.command], scope='window')
def completion_item_del(self): def completion_item_del(self):

View File

@ -1415,8 +1415,7 @@ KEY_SECTION_DESC = {
"Useful hidden commands to map in this section:\n\n" "Useful hidden commands to map in this section:\n\n"
" * `command-history-prev`: Switch to previous command in history.\n" " * `command-history-prev`: Switch to previous command in history.\n"
" * `command-history-next`: Switch to next command in history.\n" " * `command-history-next`: Switch to next command in history.\n"
" * `completion-item-prev`: Select previous item in completion.\n" " * `completion-item-focus`: Select another item in completion.\n"
" * `completion-item-next`: Select next item in completion.\n"
" * `command-accept`: Execute the command currently in the " " * `command-accept`: Execute the command currently in the "
"commandline."), "commandline."),
'prompt': ( 'prompt': (
@ -1589,8 +1588,8 @@ KEY_DATA = collections.OrderedDict([
('command', collections.OrderedDict([ ('command', collections.OrderedDict([
('command-history-prev', ['<Ctrl-P>']), ('command-history-prev', ['<Ctrl-P>']),
('command-history-next', ['<Ctrl-N>']), ('command-history-next', ['<Ctrl-N>']),
('completion-item-prev', ['<Shift-Tab>', '<Up>']), ('completion-item-focus prev', ['<Shift-Tab>', '<Up>']),
('completion-item-next', ['<Tab>', '<Down>']), ('completion-item-focus next', ['<Tab>', '<Down>']),
('completion-item-del', ['<Ctrl-D>']), ('completion-item-del', ['<Ctrl-D>']),
('command-accept', RETURN_KEYS), ('command-accept', RETURN_KEYS),
])), ])),
@ -1686,4 +1685,7 @@ CHANGED_KEY_COMMANDS = [
(re.compile(r'^yank -p'), r'yank pretty-url'), (re.compile(r'^yank -p'), r'yank pretty-url'),
(re.compile(r'^yank-selected -p'), r'yank selection -s'), (re.compile(r'^yank-selected -p'), r'yank selection -s'),
(re.compile(r'^yank-selected'), r'yank selection'), (re.compile(r'^yank-selected'), r'yank selection'),
(re.compile(r'^completion-item-next'), r'completion-item-focus next'),
(re.compile(r'^completion-item-prev'), r'completion-item-focus prev'),
] ]

View File

@ -122,7 +122,7 @@ def test_maybe_resize_completion(completionview, config_stub, qtbot):
([[]], 1, None), ([[]], 1, None),
([[]], -1, None), ([[]], -1, None),
]) ])
def test_completion_item_next_prev(tree, count, expected, completionview): def test_completion_item_focus(tree, count, expected, completionview):
"""Test that on_next_prev_item moves the selection properly. """Test that on_next_prev_item moves the selection properly.
Args: Args:
@ -140,21 +140,18 @@ def test_completion_item_next_prev(tree, count, expected, completionview):
filtermodel = sortfilter.CompletionFilterModel(model, filtermodel = sortfilter.CompletionFilterModel(model,
parent=completionview) parent=completionview)
completionview.set_model(filtermodel) completionview.set_model(filtermodel)
if count < 0: direction = 'prev' if count < 0 else 'next'
for _ in range(-count): for _ in range(abs(count)):
completionview.completion_item_prev() completionview.completion_item_focus(direction)
else:
for _ in range(count):
completionview.completion_item_next()
idx = completionview.selectionModel().currentIndex() idx = completionview.selectionModel().currentIndex()
assert filtermodel.data(idx) == expected assert filtermodel.data(idx) == expected
def test_completion_item_next_prev_no_model(completionview): def test_completion_item_focus_no_model(completionview):
"""Test that next/prev won't crash with no model set. """Test that next/prev won't crash with no model set.
This can happen if completion.show and completion.auto-open are False. This can happen if completion.show and completion.auto-open are False.
Regression test for issue #1722. Regression test for issue #1722.
""" """
completionview.completion_item_prev() completionview.completion_item_focus('prev')
completionview.completion_item_next() completionview.completion_item_focus('next')