所以我有一个QTreeView小部件,它有一个自定义的QSortFilterProxyModel作为源模型,它本身包含一个名为sourceModel
的自定义QAbstractItemModel。
我的树显示文件和文件夹。如果文件删除使文件夹为空,则会自动删除该文件夹。实施如下:
bool sourceModel::removeRows(int row, int count, const QModelIndex& parent)
{
if (parent.isValid())
{
auto parent_node = static_cast<Node*>(parent.internalPointer());
if (!parent.data(rootNode).toBool())
{
beginRemoveRows(parent, row, row + count - 1);
for (int i = 0; i < count; ++i)
parent_node->removeChild(row + i);
endRemoveRows();
if (parent_node->isType<Folder>() && parent_node->children() == 0)
{
removeRows(parent_node->row(), 1, parent.parent());
}
return true;
}
}
}
这通过代理模型调用removeRows时工作正常,但在另一个实例中,当sourceModel直接调用removeRows时,我得到:
QSortFilterProxyModel:源模型报告的不一致更改
就像QSortFilterProxyModel没有正确接收或处理beginRemoveRows / endRemoveRows一样。
我已经解决了这个问题,修复与模型本身无关,并且发布的代码工作正常。我直接从上下文菜单工作流调用方法,这导致代理模型和选择模型之间存在某种竞争条件。