Rewrite HintManager.fire to use handler dicts
This commit is contained in:
parent
9ef956ae5e
commit
9fd7f8b975
@ -207,13 +207,16 @@ class HintManager(QObject):
|
|||||||
css, string))
|
css, string))
|
||||||
return doc.lastChild()
|
return doc.lastChild()
|
||||||
|
|
||||||
def _click(self, elem, target):
|
def _click(self, elem):
|
||||||
"""Click an element.
|
"""Click an element.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
elem: The QWebElement to click.
|
elem: The QWebElement to click.
|
||||||
target: The target to use for opening links.
|
|
||||||
"""
|
"""
|
||||||
|
if self._target == 'rapid':
|
||||||
|
target = 'bgtab'
|
||||||
|
else:
|
||||||
|
target = self._target
|
||||||
self.set_open_target.emit(target)
|
self.set_open_target.emit(target)
|
||||||
point = elem.geometry().topLeft()
|
point = elem.geometry().topLeft()
|
||||||
scrollpos = self._frame.scrollPosition()
|
scrollpos = self._frame.scrollPosition()
|
||||||
@ -232,18 +235,32 @@ class HintManager(QObject):
|
|||||||
for evt in events:
|
for evt in events:
|
||||||
self.mouse_event.emit(evt)
|
self.mouse_event.emit(evt)
|
||||||
|
|
||||||
def _yank(self, link, sel):
|
def _yank(self, link):
|
||||||
"""Yank an element to the clipboard or primary selection.
|
"""Yank an element to the clipboard or primary selection.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
link: The URL to open.
|
link: The URL to open.
|
||||||
sel: True to yank to the primary selection, False for clipboard.
|
|
||||||
"""
|
"""
|
||||||
|
sel = self._target == 'yank_primary'
|
||||||
mode = QClipboard.Selection if sel else QClipboard.Clipboard
|
mode = QClipboard.Selection if sel else QClipboard.Clipboard
|
||||||
QApplication.clipboard().setText(urlutils.urlstring(link), mode)
|
QApplication.clipboard().setText(urlutils.urlstring(link), mode)
|
||||||
message.info("URL yanked to {}".format("primary selection" if sel
|
message.info("URL yanked to {}".format("primary selection" if sel
|
||||||
else "clipboard"))
|
else "clipboard"))
|
||||||
|
|
||||||
|
def _preset_cmd_text(self, link):
|
||||||
|
"""Preset a commandline text based on a hint URL.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
link: The link to open.
|
||||||
|
"""
|
||||||
|
commands = {
|
||||||
|
'cmd': 'open',
|
||||||
|
'cmd_tab': 'tabopen',
|
||||||
|
'cmd_bgtab': 'backtabopen',
|
||||||
|
}
|
||||||
|
message.set_cmd_text(':{} {}'.format(commands[self._target],
|
||||||
|
urlutils.urlstring(link)))
|
||||||
|
|
||||||
def _resolve_link(self, elem):
|
def _resolve_link(self, elem):
|
||||||
"""Resolve a link and check if we want to keep it.
|
"""Resolve a link and check if we want to keep it.
|
||||||
|
|
||||||
@ -331,29 +348,30 @@ class HintManager(QObject):
|
|||||||
self.handle_partial_key(keystr)
|
self.handle_partial_key(keystr)
|
||||||
self._to_follow = keystr
|
self._to_follow = keystr
|
||||||
return
|
return
|
||||||
# Targets which require a valid link
|
# Handlers which take a QWebElement
|
||||||
require_link = ['yank', 'yank_primary', 'cmd', 'cmd_tab', 'cmd_bgtab']
|
elem_handlers = {
|
||||||
|
'normal': self._click,
|
||||||
|
'tab': self._click,
|
||||||
|
'bgtab': self._click,
|
||||||
|
'rapid': self._click,
|
||||||
|
}
|
||||||
|
# Handlers which take a link string
|
||||||
|
link_handlers = {
|
||||||
|
'yank': self._yank,
|
||||||
|
'yank_primary': self._yank,
|
||||||
|
'cmd': self._preset_cmd_text,
|
||||||
|
'cmd_tab': self._preset_cmd_text,
|
||||||
|
'cmd_bgtab': self._preset_cmd_text,
|
||||||
|
}
|
||||||
elem = self._elems[keystr].elem
|
elem = self._elems[keystr].elem
|
||||||
if self._target in require_link:
|
if self._target in elem_handlers:
|
||||||
|
elem_handlers[self._target](elem)
|
||||||
|
elif self._target in link_handlers:
|
||||||
link = self._resolve_link(elem)
|
link = self._resolve_link(elem)
|
||||||
if link is None:
|
if link is None:
|
||||||
message.error("No suitable link found for this element.")
|
message.error("No suitable link found for this element.")
|
||||||
return
|
return
|
||||||
if self._target in ['normal', 'tab', 'bgtab']:
|
link_handlers[self._target](link)
|
||||||
self._click(elem, self._target)
|
|
||||||
elif self._target == 'rapid':
|
|
||||||
self._click(elem, 'bgtab')
|
|
||||||
elif self._target in ['yank', 'yank_primary']:
|
|
||||||
sel = self._target == 'yank_primary'
|
|
||||||
self._yank(link, sel)
|
|
||||||
elif self._target in ['cmd', 'cmd_tab', 'cmd_bgtab']:
|
|
||||||
commands = {
|
|
||||||
'cmd': 'open',
|
|
||||||
'cmd_tab': 'tabopen',
|
|
||||||
'cmd_bgtab': 'backtabopen',
|
|
||||||
}
|
|
||||||
message.set_cmd_text(':{} {}'.format(commands[self._target],
|
|
||||||
urlutils.urlstring(link)))
|
|
||||||
if self._target != 'rapid':
|
if self._target != 'rapid':
|
||||||
modeman.leave('hint')
|
modeman.leave('hint')
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user