Fixed: Remove all directories from data excepted fonts one

--HG--
branch : develop
This commit is contained in:
kervala 2016-09-28 23:29:02 +02:00
parent 5d4bdf8f60
commit 9557aff2cc
2 changed files with 33 additions and 9 deletions

View file

@ -639,20 +639,28 @@ bool CConfigFile::foundTemporaryFiles(const QString &directory) const
QStringList filter; QStringList filter;
filter << "*.string_cache"; filter << "*.string_cache";
// certificate should be in gamedev.bnp now
filter << "*.pem";
// only .ref files should be there
filter << "exedll*.bnp";
if (dir.exists("packedsheets.bnp")) if (dir.exists("packedsheets.bnp"))
{ {
filter << "*.packed_sheets"; filter << "*.packed_sheets";
filter << "*.packed"; filter << "*.packed";
filter << "*.pem";
} }
// temporary files // temporary files
if (!dir.entryList(filter, QDir::Files).isEmpty()) return true; if (!dir.entryList(filter, QDir::Files).isEmpty()) return true;
// fonts directory is not needed anymore // temporary directories
if (dir.exists("fonts.bnp") && !dir.cd("fonts")) return true; QStringList dirs = dir.entryList(QDir::Dirs | QDir::NoDotAndDotDot);
return false; // fonts directory is not needed anymore if fonts.bnp exists
if (!dir.exists("fonts.bnp")) dirs.removeAll("fonts");
return !dirs.isEmpty();
} }
bool CConfigFile::shouldCreateDesktopShortcut() const bool CConfigFile::shouldCreateDesktopShortcut() const

View file

@ -60,12 +60,21 @@ bool CFilesCleaner::exec()
filter << "*.packed"; filter << "*.packed";
} }
// only .ref files should be there
filter << "exedll*.bnp";
// temporary files // temporary files
QStringList files = dir.entryList(filter, QDir::Files); QStringList files = dir.entryList(filter, QDir::Files);
// temporary directories
QStringList dirs = dir.entryList(QDir::Dirs | QDir::NoDotAndDotDot);
// fonts directory is not needed anymore if fonts.bnp exists
if (!dir.exists("fonts.bnp")) dirs.removeAll("fonts");
if (m_listener) if (m_listener)
{ {
m_listener->operationInit(0, files.size()); m_listener->operationInit(0, files.size() + dirs.size());
m_listener->operationStart(); m_listener->operationStart();
} }
@ -80,13 +89,20 @@ bool CFilesCleaner::exec()
++filesCount; ++filesCount;
} }
// fonts directory is not needed anymore if fonts.bnp exists foreach(const QString &d, dirs)
if (dir.exists("fonts.bnp") && dir.cd("fonts")) {
if (dir.cd(d))
{ {
dir.removeRecursively(); dir.removeRecursively();
dir.cdUp();
} }
if (m_listener) m_listener->operationSuccess(files.size()); if (m_listener) m_listener->operationProgress(filesCount, d);
++filesCount;
}
if (m_listener) m_listener->operationSuccess(files.size() + dirs.size());
return true; return true;
} }