Store complete model correctly

This commit is contained in:
Florian Bruhin 2014-03-21 19:19:55 +01:00
parent ed4f168779
commit a643bcd617
2 changed files with 24 additions and 20 deletions

View File

@ -32,12 +32,15 @@ class CompletionFilterModel(QSortFilterProxyModel):
"""Subclass of QSortFilterProxyModel with custom sorting/filtering. """Subclass of QSortFilterProxyModel with custom sorting/filtering.
Attributes: Attributes:
srcmodel: The source model of this QSFPM.
_pattern: The pattern to filter with, used in pattern property. _pattern: The pattern to filter with, used in pattern property.
""" """
def __init__(self, parent=None): def __init__(self, source, parent=None):
super().__init__(parent) super().__init__(parent)
super().setSourceModel(source)
self.srcmodel = source
self._pattern = '' self._pattern = ''
@property @property
@ -61,12 +64,11 @@ class CompletionFilterModel(QSortFilterProxyModel):
self._pattern = val self._pattern = val
self.invalidateFilter() self.invalidateFilter()
sortcol = 0 sortcol = 0
if self.sourceModel() is not None: try:
try: self.srcmodel.sort(sortcol)
self.sourceModel().sort(sortcol) except NotImplementedError:
except NotImplementedError: self.sort(sortcol)
self.sort(sortcol) self.invalidate()
self.invalidate()
def first_item(self): def first_item(self):
"""Return the first item in the model.""" """Return the first item in the model."""
@ -82,6 +84,7 @@ class CompletionFilterModel(QSortFilterProxyModel):
"""Override QSortFilterProxyModel's setSourceModel to clear pattern.""" """Override QSortFilterProxyModel's setSourceModel to clear pattern."""
logging.debug("Setting source model: {}".format(model)) logging.debug("Setting source model: {}".format(model))
self.pattern = '' self.pattern = ''
self.srcmodel = model
super().setSourceModel(model) super().setSourceModel(model)
def filterAcceptsRow(self, row, parent): def filterAcceptsRow(self, row, parent):
@ -100,8 +103,8 @@ class CompletionFilterModel(QSortFilterProxyModel):
""" """
if parent == QModelIndex(): if parent == QModelIndex():
return True return True
idx = self.sourceModel().index(row, 0, parent) idx = self.srcmodel.index(row, 0, parent)
data = self.sourceModel().data(idx).value() data = self.srcmodel.data(idx).value()
# TODO more sophisticated filtering # TODO more sophisticated filtering
if not self.pattern: if not self.pattern:
return True return True
@ -121,8 +124,8 @@ class CompletionFilterModel(QSortFilterProxyModel):
True if left < right, else False True if left < right, else False
""" """
left = self.sourceModel().data(lindex).value() left = self.srcmodel.data(lindex).value()
right = self.sourceModel().data(rindex).value() right = self.srcmodel.data(rindex).value()
leftstart = left.startswith(self.pattern) leftstart = left.startswith(self.pattern)
rightstart = right.startswith(self.pattern) rightstart = right.startswith(self.pattern)

View File

@ -49,6 +49,7 @@ class CompletionView(QTreeView):
Highlights completions based on marks in the UserRole. Highlights completions based on marks in the UserRole.
Attributes: Attributes:
model: The currently active filter model.
_STYLESHEET: The stylesheet template for the CompletionView. _STYLESHEET: The stylesheet template for the CompletionView.
_completion_models: dict of available completion models. _completion_models: dict of available completion models.
_ignore_next: Whether to ignore the next cmd_text_changed signal. _ignore_next: Whether to ignore the next cmd_text_changed signal.
@ -99,16 +100,13 @@ class CompletionView(QTreeView):
def __init__(self, parent=None): def __init__(self, parent=None):
super().__init__(parent) super().__init__(parent)
self._enabled = config.config.get('general', 'show_completion') self._enabled = config.config.get('general', 'show_completion')
self._completion_models = {} self._completion_models = {
self._completion_models[''] = None 'command': CompletionFilterModel(CommandCompletionModel(self)),
self._completion_models['command'] = CompletionFilterModel( 'setting': CompletionFilterModel(SettingCompletionModel(self)),
CommandCompletionModel()) }
self._completion_models['setting'] = CompletionFilterModel(
SettingCompletionModel())
self._ignore_next = False self._ignore_next = False
self._completing = False self._completing = False
self.set_model('command')
self._delegate = _CompletionItemDelegate(self) self._delegate = _CompletionItemDelegate(self)
self.setItemDelegate(self._delegate) self.setItemDelegate(self._delegate)
self.setStyleSheet(get_stylesheet(self._STYLESHEET)) self.setStyleSheet(get_stylesheet(self._STYLESHEET))
@ -122,6 +120,7 @@ class CompletionView(QTreeView):
# Some background: http://bugs.quassel-irc.org/issues/663 # Some background: http://bugs.quassel-irc.org/issues/663
# The proposed fix there was later reverted because it didn't help. # The proposed fix there was later reverted because it didn't help.
self.setUniformRowHeights(True) self.setUniformRowHeights(True)
self.set_model('command')
self.hide() self.hide()
# FIXME set elidemode # FIXME set elidemode
@ -161,7 +160,9 @@ class CompletionView(QTreeView):
model: An index into self._completion_models. model: An index into self._completion_models.
""" """
self.setModel(self._completion_models[model]) m = self._completion_models[model]
self.setModel(m)
self.model = m
self.expandAll() self.expandAll()
self.resizeColumnToContents(0) self.resizeColumnToContents(0)
@ -205,7 +206,7 @@ class CompletionView(QTreeView):
text = text.split()[-1] text = text.split()[-1]
logging.debug("pattern: {}".format(text)) logging.debug("pattern: {}".format(text))
self.model.pattern = text self.model.pattern = text
self.model.sourceModel().mark_all_items(text) self.model.srcmodel.mark_all_items(text)
if self._enabled: if self._enabled:
self.show() self.show()