Browse Source

Improve Torrent content tree structure creation

Use QHash to cache folder items.
PR #16183.
adaptive-webui-19844
Prince Gupta 3 years ago committed by GitHub
parent
commit
0cc318664d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 8
      src/gui/torrentcontentmodel.cpp
  2. 11
      src/gui/torrentcontentmodelfolder.cpp
  3. 1
      src/gui/torrentcontentmodelfolder.h

8
src/gui/torrentcontentmodel.cpp

@ -498,6 +498,7 @@ void TorrentContentModel::setupModelData(const BitTorrent::AbstractFileStorage & @@ -498,6 +498,7 @@ void TorrentContentModel::setupModelData(const BitTorrent::AbstractFileStorage &
m_filesIndex.reserve(filesCount);
TorrentContentModelFolder *currentParent;
QHash<TorrentContentModelFolder *, QHash<QString, TorrentContentModelFolder *>> folderMap;
// Iterate over files
for (int i = 0; i < filesCount; ++i)
{
@ -510,13 +511,14 @@ void TorrentContentModel::setupModelData(const BitTorrent::AbstractFileStorage & @@ -510,13 +511,14 @@ void TorrentContentModel::setupModelData(const BitTorrent::AbstractFileStorage &
for (const QStringView pathPart : asConst(pathFolders))
{
const QString folderPath = pathPart.toString();
TorrentContentModelFolder *newParent = currentParent->childFolderWithName(folderPath);
const QString folderName = pathPart.toString();
TorrentContentModelFolder *&newParent = folderMap[currentParent][folderName];
if (!newParent)
{
newParent = new TorrentContentModelFolder(folderPath, currentParent);
newParent = new TorrentContentModelFolder(folderName, currentParent);
currentParent->appendChild(newParent);
}
currentParent = newParent;
}
// Actually create the file

11
src/gui/torrentcontentmodelfolder.cpp

@ -81,17 +81,6 @@ TorrentContentModelItem *TorrentContentModelFolder::child(int row) const @@ -81,17 +81,6 @@ TorrentContentModelItem *TorrentContentModelFolder::child(int row) const
{
return m_childItems.value(row, nullptr);
}
TorrentContentModelFolder *TorrentContentModelFolder::childFolderWithName(const QString &name) const
{
for (TorrentContentModelItem *child : asConst(m_childItems))
{
if ((child->itemType() == FolderType) && (child->name() == name))
return static_cast<TorrentContentModelFolder *>(child);
}
return nullptr;
}
int TorrentContentModelFolder::childCount() const
{
return m_childItems.count();

1
src/gui/torrentcontentmodelfolder.h

@ -59,7 +59,6 @@ public: @@ -59,7 +59,6 @@ public:
const QVector<TorrentContentModelItem*> &children() const;
void appendChild(TorrentContentModelItem *item);
TorrentContentModelItem *child(int row) const;
TorrentContentModelFolder *childFolderWithName(const QString &name) const;
int childCount() const;
private:

Loading…
Cancel
Save