Optimize ListModel setProperty() and update()

Avoid emiting dataChanged signals when nothing actually changed
This commit is contained in:
miruka 2019-05-09 16:08:34 -04:00
parent 4367f52ce5
commit df088a8daa

View File

@ -1,7 +1,7 @@
import logging
from typing import (
Any, Callable, Dict, Iterable, List, Mapping, MutableSequence, Optional,
Sequence, Tuple, Union
Sequence, Set, Tuple, Union
)
from PyQt5.QtCore import (
@ -217,18 +217,26 @@ class ListModel(QAbstractListModel):
to_update = self[i_index]
for role in self.roles:
if role not in ignore_roles:
updated_roles: Set[int] = set()
for role_name, role_num in self.roleNumbers().items():
if role_name not in ignore_roles:
old_value = getattr(to_update, role_name)
new_value = getattr(value, role_name)
if old_value != new_value:
try:
setattr(to_update, role, getattr(value, role))
setattr(to_update, role_name, new_value)
except AttributeError: # constant/not settable
pass
else:
updated_roles.add(role_num)
if updated_roles:
qidx = QAbstractListModel.index(self, i_index, 0)
updated = [number for name, number in self.roleNumbers().items()
if name not in ignore_roles]
self.dataChanged.emit(qidx, qidx, updated)
self.dataChanged.emit(qidx, qidx, updated_roles)
self.changed.emit()
return i_index
@ -270,6 +278,7 @@ class ListModel(QAbstractListModel):
i_index: int = self.indexWhere(self.mainKey, index) \
if isinstance(index, str) else index
if getattr(self[i_index], prop) != value:
setattr(self[i_index], prop, value)
qidx = QAbstractListModel.index(self, i_index, 0)
self.dataChanged.emit(qidx, qidx, (self.roleNumbers()[prop],))