From 79cdca3fb29ed71adbdb4d10cdded616a93d3062 Mon Sep 17 00:00:00 2001 From: RJ <122295667+Liderate@users.noreply.github.com> Date: Thu, 3 Oct 2024 03:49:14 -0400 Subject: [PATCH] Refactor loop to use QHash and ensure SimpleFileTreeModel destructor is called (#13) * Use QHash to see if child item was already added * Pass parent to model so its destructor is called --------- Co-authored-by: RJ --- src/previewbsa.cpp | 2 +- src/simplefiletreeitem.cpp | 8 +++++++- src/simplefiletreeitem.h | 4 +++- src/simplefiletreemodel.cpp | 14 +++----------- 4 files changed, 14 insertions(+), 14 deletions(-) diff --git a/src/previewbsa.cpp b/src/previewbsa.cpp index 6a467ed..88ab14c 100644 --- a/src/previewbsa.cpp +++ b/src/previewbsa.cpp @@ -159,7 +159,7 @@ QWidget* PreviewBsa::genBsaPreview(const QString& fileName, const QSize&) layout->addWidget(infoLabel); QTreeView* view = new QTreeView(); - SimpleFileTreeModel* model = new SimpleFileTreeModel(m_Files); + SimpleFileTreeModel* model = new SimpleFileTreeModel(m_Files, view); view->setModel(model); layout->addWidget(view); diff --git a/src/simplefiletreeitem.cpp b/src/simplefiletreeitem.cpp index 64fab2a..5bcc5d4 100644 --- a/src/simplefiletreeitem.cpp +++ b/src/simplefiletreeitem.cpp @@ -18,9 +18,10 @@ SimpleFileTreeItem::~SimpleFileTreeItem() qDeleteAll(m_childItems); } -void SimpleFileTreeItem::appendChild(SimpleFileTreeItem* item) +void SimpleFileTreeItem::appendChild(const QString& name, SimpleFileTreeItem* item) { m_childItems.append(item); + m_childItemsByName.insert(name, item); } SimpleFileTreeItem* SimpleFileTreeItem::child(int row) @@ -30,6 +31,11 @@ SimpleFileTreeItem* SimpleFileTreeItem::child(int row) return m_childItems.at(row); } +SimpleFileTreeItem* SimpleFileTreeItem::childByName(const QString& name) +{ + return m_childItemsByName.value(name); +} + QVector SimpleFileTreeItem::children() { return m_childItems; diff --git a/src/simplefiletreeitem.h b/src/simplefiletreeitem.h index 79da740..3d5ddd7 100644 --- a/src/simplefiletreeitem.h +++ b/src/simplefiletreeitem.h @@ -11,9 +11,10 @@ class SimpleFileTreeItem SimpleFileTreeItem* parentItem = nullptr); ~SimpleFileTreeItem(); - void appendChild(SimpleFileTreeItem* child); + void appendChild(const QString& name, SimpleFileTreeItem* child); SimpleFileTreeItem* child(int row); + SimpleFileTreeItem* childByName(const QString& name); QVector children(); int childCount() const; int columnCount() const; @@ -23,6 +24,7 @@ class SimpleFileTreeItem private: QVector m_childItems; + QHash m_childItemsByName; QVector m_itemData; SimpleFileTreeItem* m_parentItem; }; diff --git a/src/simplefiletreemodel.cpp b/src/simplefiletreemodel.cpp index 428cc69..4d331b3 100644 --- a/src/simplefiletreemodel.cpp +++ b/src/simplefiletreemodel.cpp @@ -130,18 +130,10 @@ void SimpleFileTreeModel::setupModelData(const QStringList& lines, auto currentParent = m_RootItem; for (int i = 0; i < lineEntries.count(); i++) { - QString currentEntryName = lineEntries[i]; - SimpleFileTreeItem* currentEntry = nullptr; + QString currentEntryName = lineEntries[i]; // check if item was already added - if (currentParent->childCount() > 0) { - for (auto child : currentParent->children()) { - if (child->data(0).toString() == currentEntryName) { - currentEntry = child; - break; - } - } - } + SimpleFileTreeItem* currentEntry = currentParent->childByName(currentEntryName); // add tree item if not found if (currentEntry == nullptr) { @@ -149,7 +141,7 @@ void SimpleFileTreeModel::setupModelData(const QStringList& lines, columnData.reserve(m_ColumnCount); columnData << currentEntryName; currentEntry = new SimpleFileTreeItem(columnData, currentParent); - currentParent->appendChild(currentEntry); + currentParent->appendChild(currentEntryName, currentEntry); } // as we go deeper into the path