From 2a5a24c51f7bce4756a58424c6f9c8c34910f746 Mon Sep 17 00:00:00 2001 From: 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> Date: Tue, 2 Sep 2025 14:32:40 +1000 Subject: plugin/fsm: incremental updates + sort --- plugin/src/Caelestia/filesystemmodel.cpp | 31 +++++++++++++++++++++---------- 1 file changed, 21 insertions(+), 10 deletions(-) (limited to 'plugin/src') diff --git a/plugin/src/Caelestia/filesystemmodel.cpp b/plugin/src/Caelestia/filesystemmodel.cpp index 0a3d31a..832e458 100644 --- a/plugin/src/Caelestia/filesystemmodel.cpp +++ b/plugin/src/Caelestia/filesystemmodel.cpp @@ -133,10 +133,9 @@ void FileSystemModel::updateEntries() { iter.emplace(m_path, QDir::Dirs | QDir::Files | QDir::NoDotAndDotDot, flags); } - QStringList newPaths; - - while (iter.value().hasNext()) { - QString path = iter.value().next(); + QSet newPaths; + while (iter->hasNext()) { + QString path = iter->next(); if (m_filter == Images) { QImageReader reader(path); @@ -145,26 +144,38 @@ void FileSystemModel::updateEntries() { } } - newPaths << path; + newPaths.insert(path); } - QStringList oldPaths; + QSet oldPaths; for (const auto& entry : m_entries) { - oldPaths << entry->path(); + oldPaths.insert(entry->path()); } if (newPaths == oldPaths) { return; } + const QSet removedPaths = oldPaths - newPaths; + const QSet addedPaths = newPaths - oldPaths; + beginResetModel(); - qDeleteAll(m_entries); - m_entries.clear(); - for (const auto& path : newPaths) { + const int numEntries = static_cast(m_entries.size()); + for (int i = numEntries - 1; i >= 0; --i) { + if (removedPaths.contains(m_entries[i]->path())) { + delete m_entries.takeAt(i); + } + } + + for (const auto& path : addedPaths) { m_entries << new FileSystemEntry(path, m_dir.relativeFilePath(path), this); } + std::sort(m_entries.begin(), m_entries.end(), [](const FileSystemEntry* a, const FileSystemEntry* b) { + return a->relativePath().localeAwareCompare(b->relativePath()) < 0; + }); + emit entriesChanged(); endResetModel(); -- cgit v1.2.3-freya