mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-24 13:34:27 +00:00
Merge pull request #3176 from DoumanAsh/py3_remove_cache
[search engine] Remove python3 cache during updateNova()
This commit is contained in:
commit
4f5ce16dcb
@ -178,6 +178,27 @@ bool Utils::Fs::forceRemove(const QString& file_path)
|
|||||||
return f.remove();
|
return f.remove();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes directory and its content recursively.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void Utils::Fs::removeDirRecursive(const QString& dirName) {
|
||||||
|
QDir dir(dirName);
|
||||||
|
|
||||||
|
if (!dir.exists()) return;
|
||||||
|
|
||||||
|
Q_FOREACH(QFileInfo info, dir.entryInfoList(QDir::NoDotAndDotDot |
|
||||||
|
QDir::System |
|
||||||
|
QDir::Hidden |
|
||||||
|
QDir::AllDirs |
|
||||||
|
QDir::Files, QDir::DirsFirst)) {
|
||||||
|
if (info.isDir()) removeDirRecursive(info.absoluteFilePath());
|
||||||
|
else forceRemove(info.absoluteFilePath());
|
||||||
|
}
|
||||||
|
|
||||||
|
dir.rmdir(dirName);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the size of a file.
|
* Returns the size of a file.
|
||||||
* If the file is a folder, it will compute its size based on its content.
|
* If the file is a folder, it will compute its size based on its content.
|
||||||
|
@ -57,6 +57,7 @@ namespace Utils
|
|||||||
QString expandPathAbs(const QString& path);
|
QString expandPathAbs(const QString& path);
|
||||||
bool smartRemoveEmptyFolderTree(const QString& dir_path);
|
bool smartRemoveEmptyFolderTree(const QString& dir_path);
|
||||||
bool forceRemove(const QString& file_path);
|
bool forceRemove(const QString& file_path);
|
||||||
|
void removeDirRecursive(const QString& dirName);
|
||||||
|
|
||||||
/* Ported from Qt4 to drop dependency on QtGui */
|
/* Ported from Qt4 to drop dependency on QtGui */
|
||||||
QString QDesktopServicesDataLocation();
|
QString QDesktopServicesDataLocation();
|
||||||
|
@ -321,7 +321,7 @@ void SearchEngine::downloadFinished(int exitcode, QProcess::ExitStatus) {
|
|||||||
delete downloadProcess;
|
delete downloadProcess;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void removePythonScriptIfExists(const QString& script_path)
|
static inline void removePythonScriptIfExists(const QString& script_path)
|
||||||
{
|
{
|
||||||
Utils::Fs::forceRemove(script_path);
|
Utils::Fs::forceRemove(script_path);
|
||||||
Utils::Fs::forceRemove(script_path + "c");
|
Utils::Fs::forceRemove(script_path + "c");
|
||||||
@ -339,6 +339,8 @@ void SearchEngine::updateNova() {
|
|||||||
if (!search_dir.exists("engines")) {
|
if (!search_dir.exists("engines")) {
|
||||||
search_dir.mkdir("engines");
|
search_dir.mkdir("engines");
|
||||||
}
|
}
|
||||||
|
Utils::Fs::removeDirRecursive(search_dir.absoluteFilePath("__pycache__"));
|
||||||
|
|
||||||
QFile package_file2(search_dir.absolutePath() + "/engines/__init__.py");
|
QFile package_file2(search_dir.absolutePath() + "/engines/__init__.py");
|
||||||
package_file2.open(QIODevice::WriteOnly | QIODevice::Text);
|
package_file2.open(QIODevice::WriteOnly | QIODevice::Text);
|
||||||
package_file2.close();
|
package_file2.close();
|
||||||
@ -376,13 +378,13 @@ void SearchEngine::updateNova() {
|
|||||||
removePythonScriptIfExists(filePath);
|
removePythonScriptIfExists(filePath);
|
||||||
QFile::copy(":/"+nova_folder+"/fix_encoding.py", filePath);
|
QFile::copy(":/"+nova_folder+"/fix_encoding.py", filePath);
|
||||||
}
|
}
|
||||||
|
else if (nova_folder == "nova3") {
|
||||||
if (nova_folder == "nova3") {
|
|
||||||
filePath = search_dir.absoluteFilePath("sgmllib3.py");
|
filePath = search_dir.absoluteFilePath("sgmllib3.py");
|
||||||
removePythonScriptIfExists(filePath);
|
removePythonScriptIfExists(filePath);
|
||||||
QFile::copy(":/"+nova_folder+"/sgmllib3.py", filePath);
|
QFile::copy(":/"+nova_folder+"/sgmllib3.py", filePath);
|
||||||
}
|
}
|
||||||
QDir destDir(QDir(Utils::Fs::searchEngineLocation()).absoluteFilePath("engines"));
|
QDir destDir(QDir(Utils::Fs::searchEngineLocation()).absoluteFilePath("engines"));
|
||||||
|
Utils::Fs::removeDirRecursive(destDir.absoluteFilePath("__pycache__"));
|
||||||
QDir shipped_subDir(":/"+nova_folder+"/engines/");
|
QDir shipped_subDir(":/"+nova_folder+"/engines/");
|
||||||
QStringList files = shipped_subDir.entryList();
|
QStringList files = shipped_subDir.entryList();
|
||||||
foreach (const QString &file, files) {
|
foreach (const QString &file, files) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user