From 386b93bb0f210d6a664b895aafa5fdd23ba7082f Mon Sep 17 00:00:00 2001 From: Chocobo1 Date: Thu, 28 Apr 2016 19:04:51 +0800 Subject: [PATCH] Fix the file size sum igonred files starting with a dot: ".name" Make the computation iterative instead of recurisve to avoid stack overflow. Enlarge read size to enable better performance. Remove `QFile::close()` calls, QFile automatically close them in dtor. --- src/base/utils/fs.cpp | 28 +++++++++++----------------- 1 file changed, 11 insertions(+), 17 deletions(-) diff --git a/src/base/utils/fs.cpp b/src/base/utils/fs.cpp index 852f4e963..4ce8aecd5 100644 --- a/src/base/utils/fs.cpp +++ b/src/base/utils/fs.cpp @@ -180,14 +180,13 @@ qint64 Utils::Fs::computePathSize(const QString& path) QFileInfo fi(path); if (!fi.exists()) return -1; if (fi.isFile()) return fi.size(); + // Compute folder size based on its content qint64 size = 0; - foreach (const QFileInfo &subfi, QDir(path).entryInfoList(QDir::Dirs|QDir::Files)) { - if (subfi.fileName().startsWith(".")) continue; - if (subfi.isDir()) - size += computePathSize(subfi.absoluteFilePath()); - else - size += subfi.size(); + QDirIterator iter(path, QDir::Files | QDir::Hidden | QDir::NoSymLinks, QDirIterator::Subdirectories); + while (iter.hasNext()) { + iter.next(); + size += iter.fileInfo().size(); } return size; } @@ -201,19 +200,14 @@ bool Utils::Fs::sameFiles(const QString& path1, const QString& path2) if (!f1.exists() || !f2.exists()) return false; if (f1.size() != f2.size()) return false; if (!f1.open(QIODevice::ReadOnly)) return false; - if (!f2.open(QIODevice::ReadOnly)) { - f1.close(); - return false; - } - bool same = true; + if (!f2.open(QIODevice::ReadOnly)) return false; + + const int readSize = 1024 * 1024; // 1 MiB while(!f1.atEnd() && !f2.atEnd()) { - if (f1.read(1024) != f2.read(1024)) { - same = false; - break; - } + if (f1.read(readSize) != f2.read(readSize)) + return false; } - f1.close(); f2.close(); - return same; + return true; } QString Utils::Fs::toValidFileSystemName(const QString &name, bool allowSeparators, const QString &pad)