Add more performance logging to completion.
This commit is contained in:
parent
a01c76db54
commit
42243d3d97
@ -23,7 +23,7 @@ from PyQt5.QtCore import pyqtSlot, QObject, QTimer
|
|||||||
|
|
||||||
from qutebrowser.config import config
|
from qutebrowser.config import config
|
||||||
from qutebrowser.commands import cmdutils, runners
|
from qutebrowser.commands import cmdutils, runners
|
||||||
from qutebrowser.utils import log, utils
|
from qutebrowser.utils import log, utils, debug
|
||||||
from qutebrowser.completion.models import miscmodels
|
from qutebrowser.completion.models import miscmodels
|
||||||
|
|
||||||
|
|
||||||
@ -227,10 +227,11 @@ class Completer(QObject):
|
|||||||
elif func != self._last_completion_func:
|
elif func != self._last_completion_func:
|
||||||
self._last_completion_func = func
|
self._last_completion_func = func
|
||||||
args = (x for x in before_cursor[1:] if not x.startswith('-'))
|
args = (x for x in before_cursor[1:] if not x.startswith('-'))
|
||||||
model = func(*args)
|
with debug.log_time(log.completion,
|
||||||
log.completion.debug('Starting {} completion'
|
'Instantiate {} completion'.format(func.__name__)):
|
||||||
.format(func.__name__))
|
model = func(*args)
|
||||||
completion.set_model(model)
|
with debug.log_time(log.completion, 'Set completion model'):
|
||||||
|
completion.set_model(model)
|
||||||
completion.set_pattern(pattern)
|
completion.set_pattern(pattern)
|
||||||
else:
|
else:
|
||||||
log.completion.debug('Setting pattern {}'.format(pattern))
|
log.completion.debug('Setting pattern {}'.format(pattern))
|
||||||
|
@ -28,7 +28,7 @@ from PyQt5.QtCore import pyqtSlot, pyqtSignal, Qt, QItemSelectionModel, QSize
|
|||||||
|
|
||||||
from qutebrowser.config import config, style
|
from qutebrowser.config import config, style
|
||||||
from qutebrowser.completion import completiondelegate
|
from qutebrowser.completion import completiondelegate
|
||||||
from qutebrowser.utils import utils, usertypes, objreg
|
from qutebrowser.utils import utils, usertypes, objreg, debug, log
|
||||||
from qutebrowser.commands import cmdexc, cmdutils
|
from qutebrowser.commands import cmdexc, cmdutils
|
||||||
|
|
||||||
|
|
||||||
@ -295,10 +295,11 @@ class CompletionView(QTreeView):
|
|||||||
self.expand(model.index(i, 0))
|
self.expand(model.index(i, 0))
|
||||||
|
|
||||||
def set_pattern(self, pattern):
|
def set_pattern(self, pattern):
|
||||||
self.model().set_pattern(pattern)
|
with debug.log_time(log.completion, 'Set pattern {}'.format(pattern)):
|
||||||
self._resize_columns()
|
self.model().set_pattern(pattern)
|
||||||
self._maybe_update_geometry()
|
self._resize_columns()
|
||||||
self.show()
|
self._maybe_update_geometry()
|
||||||
|
self.show()
|
||||||
|
|
||||||
def _maybe_update_geometry(self):
|
def _maybe_update_geometry(self):
|
||||||
"""Emit the update_geometry signal if the config says so."""
|
"""Emit the update_geometry signal if the config says so."""
|
||||||
|
@ -52,15 +52,14 @@ class ListCategory(QSortFilterProxyModel):
|
|||||||
Args:
|
Args:
|
||||||
val: The value to set.
|
val: The value to set.
|
||||||
"""
|
"""
|
||||||
with debug.log_time(log.completion, 'Setting filter pattern'):
|
self.pattern = val
|
||||||
self.pattern = val
|
val = re.sub(r' +', r' ', val) # See #1919
|
||||||
val = re.sub(r' +', r' ', val) # See #1919
|
val = re.escape(val)
|
||||||
val = re.escape(val)
|
val = val.replace(r'\ ', '.*')
|
||||||
val = val.replace(r'\ ', '.*')
|
self.pattern_re = re.compile(val, re.IGNORECASE)
|
||||||
self.pattern_re = re.compile(val, re.IGNORECASE)
|
self.invalidate()
|
||||||
self.invalidate()
|
sortcol = 0
|
||||||
sortcol = 0
|
self.sort(sortcol)
|
||||||
self.sort(sortcol)
|
|
||||||
|
|
||||||
def filterAcceptsRow(self, row, parent):
|
def filterAcceptsRow(self, row, parent):
|
||||||
"""Custom filter implementation.
|
"""Custom filter implementation.
|
||||||
|
@ -24,5 +24,5 @@ bdd.scenarios('completion.feature')
|
|||||||
@bdd.then(bdd.parsers.parse("the completion model should be {model}"))
|
@bdd.then(bdd.parsers.parse("the completion model should be {model}"))
|
||||||
def check_model(quteproc, model):
|
def check_model(quteproc, model):
|
||||||
"""Make sure the completion model was set to something."""
|
"""Make sure the completion model was set to something."""
|
||||||
pattern = "Starting {} completion".format(model)
|
pattern = "Starting {} completion *".format(model)
|
||||||
quteproc.wait_for(message=pattern)
|
quteproc.wait_for(message=pattern)
|
||||||
|
Loading…
Reference in New Issue
Block a user