From 885eb64df337513c1519af176703cb760a8ca40d Mon Sep 17 00:00:00 2001 From: Gabriele Date: Tue, 28 Jul 2015 22:55:40 +0200 Subject: [PATCH] Follow project coding style. Issue #2192. --- src/searchengine/searchengine.cpp | 185 ++++++++++++++++-------------- 1 file changed, 97 insertions(+), 88 deletions(-) diff --git a/src/searchengine/searchengine.cpp b/src/searchengine/searchengine.cpp index d56ebefab..cd025ea10 100644 --- a/src/searchengine/searchengine.cpp +++ b/src/searchengine/searchengine.cpp @@ -62,9 +62,9 @@ /*SEARCH ENGINE START*/ SearchEngine::SearchEngine(MainWindow* parent) - : QWidget(parent) - , search_pattern(new LineEdit) - , mp_mainWindow(parent) + : QWidget(parent) + , search_pattern(new LineEdit) + , mp_mainWindow(parent) { setupUi(this); searchBarLayout->insertWidget(0, search_pattern); @@ -96,20 +96,22 @@ SearchEngine::SearchEngine(MainWindow* parent) fillEngineComboBox(); connect(search_pattern, SIGNAL(textEdited(QString)), this, SLOT(searchTextEdited(QString))); - connect(selectEngine, SIGNAL(currentIndexChanged(const QString&)), this, SLOT(selectMultipleBox(const QString&))); + connect(selectEngine, SIGNAL(currentIndexChanged(const QString &)), this, SLOT(selectMultipleBox(const QString &))); } -void SearchEngine::fillCatCombobox() { +void SearchEngine::fillCatCombobox() +{ comboCategory->clear(); comboCategory->addItem(full_cat_names["all"], QVariant("all")); QStringList supported_cat = supported_engines->supportedCategories(); foreach (QString cat, supported_cat) { qDebug("Supported category: %s", qPrintable(cat)); comboCategory->addItem(full_cat_names[cat], QVariant(cat)); - } + } } -void SearchEngine::fillEngineComboBox() { +void SearchEngine::fillEngineComboBox() +{ selectEngine->clear(); selectEngine->addItem(tr("All enabled"), QVariant("enabled")); selectEngine->addItem(tr("All engines"), QVariant("all")); @@ -118,15 +120,18 @@ void SearchEngine::fillEngineComboBox() { selectEngine->addItem(tr("Multiple..."), QVariant("multi")); } -QString SearchEngine::selectedCategory() const { +QString SearchEngine::selectedCategory() const +{ return comboCategory->itemData(comboCategory->currentIndex()).toString(); } -QString SearchEngine::selectedEngine() const { +QString SearchEngine::selectedEngine() const +{ return selectEngine->itemData(selectEngine->currentIndex()).toString(); } -SearchEngine::~SearchEngine() { +SearchEngine::~SearchEngine() +{ qDebug("Search destruction"); searchProcess->kill(); searchProcess->waitForFinished(); @@ -145,9 +150,11 @@ SearchEngine::~SearchEngine() { } void SearchEngine::tab_changed(int t) -{//when we switch from a tab that is not empty to another that is empty the download button - //doesn't have to be available - if (t>-1) {//-1 = no more tab +{ + //when we switch from a tab that is not empty to another that is empty the download button + //doesn't have to be available + if (t > -1) { + //-1 = no more tab currentSearchTab = all_tab.at(tabWidget->currentIndex()); if (currentSearchTab->getCurrentSearchListModel()->rowCount()) { download_button->setEnabled(true); @@ -161,27 +168,32 @@ void SearchEngine::tab_changed(int t) } } -void SearchEngine::selectMultipleBox(const QString &text) { +void SearchEngine::selectMultipleBox(const QString &text) +{ if (text == tr("Multiple...")) on_enginesButton_clicked(); } -void SearchEngine::on_enginesButton_clicked() { +void SearchEngine::on_enginesButton_clicked() +{ engineSelectDlg *dlg = new engineSelectDlg(this, supported_engines); connect(dlg, SIGNAL(enginesChanged()), this, SLOT(fillCatCombobox())); connect(dlg, SIGNAL(enginesChanged()), this, SLOT(fillEngineComboBox())); } -void SearchEngine::searchTextEdited(QString) { +void SearchEngine::searchTextEdited(QString) +{ // Enable search button search_button->setText(tr("Search")); } -void SearchEngine::giveFocusToSearchInput() { +void SearchEngine::giveFocusToSearchInput() +{ search_pattern->setFocus(); } // Function called when we click on search button -void SearchEngine::on_search_button_clicked() { +void SearchEngine::on_search_button_clicked() +{ if (Utils::Misc::pythonVersion() < 0) { mp_mainWindow->showNotificationBaloon(tr("Search Engine"), tr("Please install Python to use the Search Engine.")); return; @@ -194,9 +206,8 @@ void SearchEngine::on_search_button_clicked() { searchProcess->terminate(); #endif search_stopped = true; - if (searchTimeout->isActive()) { + if (searchTimeout->isActive()) searchTimeout->stop(); - } if (search_button->text() != tr("Search")) { search_button->setText(tr("Search")); return; @@ -239,29 +250,30 @@ void SearchEngine::on_search_button_clicked() { nb_search_results = 0; search_result_line_truncated.clear(); // Changing the text of the current label - currentSearchTab->getCurrentLabel()->setText(tr("Results")+" (0):"); + currentSearchTab->getCurrentLabel()->setText(tr("Results") + " (0):"); // Launch search searchProcess->start(Utils::Misc::pythonExecutable(), params, QIODevice::ReadOnly); searchTimeout->start(180000); // 3min } -void SearchEngine::saveResultsColumnsWidth() { +void SearchEngine::saveResultsColumnsWidth() +{ if (all_tab.isEmpty()) return; QTreeView* treeview = all_tab.first()->getCurrentTreeView(); Preferences* const pref = Preferences::instance(); QStringList new_width_list; short nbColumns = all_tab.first()->getCurrentSearchListModel()->columnCount(); - for (short i=0; icolumnWidth(i) > 0) new_width_list << QString::number(treeview->columnWidth(i)); - } // Don't save the width of the last column (auto column width) new_width_list.removeLast(); pref->setSearchColsWidth(new_width_list.join(" ")); } -void SearchEngine::downloadTorrent(QString engine_url, QString torrent_url) { +void SearchEngine::downloadTorrent(QString engine_url, QString torrent_url) +{ if (torrent_url.startsWith("bc://bt/", Qt::CaseInsensitive)) { qDebug("Converting bc link to magnet link"); torrent_url = Utils::Misc::bcLinkToMagnet(torrent_url); @@ -271,7 +283,8 @@ void SearchEngine::downloadTorrent(QString engine_url, QString torrent_url) { QStringList urls; urls << torrent_url; mp_mainWindow->downloadFromURLList(urls); - } else { + } + else { QProcess *downloadProcess = new QProcess(this); downloadProcess->setEnvironment(QProcess::systemEnvironment()); connect(downloadProcess, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(downloadFinished(int,QProcess::ExitStatus))); @@ -285,7 +298,8 @@ void SearchEngine::downloadTorrent(QString engine_url, QString torrent_url) { } } -void SearchEngine::searchStarted() { +void SearchEngine::searchStarted() +{ // Update SearchEngine widgets activeSearchTab->status = tr("Searching..."); search_status->setText(activeSearchTab->status); @@ -296,23 +310,24 @@ void SearchEngine::searchStarted() { // search Qprocess return output as soon as it gets new // stuff to read. We split it into lines and add each // line to search results calling appendSearchResult(). -void SearchEngine::readSearchOutput() { +void SearchEngine::readSearchOutput() +{ QByteArray output = searchProcess->readAllStandardOutput(); output.replace("\r", ""); QList lines_list = output.split('\n'); if (!search_result_line_truncated.isEmpty()) { QByteArray end_of_line = lines_list.takeFirst(); - lines_list.prepend(search_result_line_truncated+end_of_line); + lines_list.prepend(search_result_line_truncated + end_of_line); } search_result_line_truncated = lines_list.takeLast().trimmed(); - foreach (const QByteArray &line, lines_list) { + foreach (const QByteArray &line, lines_list) appendSearchResult(QString::fromUtf8(line)); - } if (activeSearchTab) - activeSearchTab->getCurrentLabel()->setText(tr("Results")+QString::fromUtf8(" (")+QString::number(nb_search_results)+QString::fromUtf8("):")); + activeSearchTab->getCurrentLabel()->setText(tr("Results") + QString::fromUtf8(" (") + QString::number(nb_search_results) + QString::fromUtf8("):")); } -void SearchEngine::downloadFinished(int exitcode, QProcess::ExitStatus) { +void SearchEngine::downloadFinished(int exitcode, QProcess::ExitStatus) +{ QProcess *downloadProcess = (QProcess*)sender(); if (exitcode == 0) { QString line = QString::fromUtf8(downloadProcess->readAllStandardOutput()).trimmed(); @@ -338,7 +353,8 @@ static inline void removePythonScriptIfExists(const QString& script_path) } // Update nova.py search plugin if necessary -void SearchEngine::updateNova() { +void SearchEngine::updateNova() +{ qDebug("Updating nova"); // create nova directory if necessary QDir search_dir(Utils::Fs::searchEngineLocation()); @@ -346,9 +362,8 @@ void SearchEngine::updateNova() { QFile package_file(search_dir.absoluteFilePath("__init__.py")); package_file.open(QIODevice::WriteOnly | QIODevice::Text); package_file.close(); - if (!search_dir.exists("engines")) { + if (!search_dir.exists("engines")) search_dir.mkdir("engines"); - } Utils::Fs::removeDirRecursive(search_dir.absoluteFilePath("__pycache__")); QFile package_file2(search_dir.absolutePath() + "/engines/__init__.py"); @@ -356,46 +371,46 @@ void SearchEngine::updateNova() { package_file2.close(); // Copy search plugin files (if necessary) QString filePath = search_dir.absoluteFilePath("nova2.py"); - if (getPluginVersion(":/"+nova_folder+"/nova2.py") > getPluginVersion(filePath)) { + if (getPluginVersion(":/" + nova_folder + "/nova2.py") > getPluginVersion(filePath)) { removePythonScriptIfExists(filePath); - QFile::copy(":/"+nova_folder+"/nova2.py", filePath); + QFile::copy(":/" + nova_folder + "/nova2.py", filePath); } filePath = search_dir.absoluteFilePath("nova2dl.py"); - if (getPluginVersion(":/"+nova_folder+"/nova2dl.py") > getPluginVersion(filePath)) { + if (getPluginVersion(":/" + nova_folder + "/nova2dl.py") > getPluginVersion(filePath)) { removePythonScriptIfExists(filePath); - QFile::copy(":/"+nova_folder+"/nova2dl.py", filePath); + QFile::copy(":/" + nova_folder + "/nova2dl.py", filePath); } filePath = search_dir.absoluteFilePath("novaprinter.py"); - if (getPluginVersion(":/"+nova_folder+"/novaprinter.py") > getPluginVersion(filePath)) { + if (getPluginVersion(":/" + nova_folder + "/novaprinter.py") > getPluginVersion(filePath)) { removePythonScriptIfExists(filePath); - QFile::copy(":/"+nova_folder+"/novaprinter.py", filePath); + QFile::copy(":/" + nova_folder + "/novaprinter.py", filePath); } filePath = search_dir.absoluteFilePath("helpers.py"); - if (getPluginVersion(":/"+nova_folder+"/helpers.py") > getPluginVersion(filePath)) { + if (getPluginVersion(":/" + nova_folder + "/helpers.py") > getPluginVersion(filePath)) { removePythonScriptIfExists(filePath); - QFile::copy(":/"+nova_folder+"/helpers.py", filePath); + QFile::copy(":/" + nova_folder + "/helpers.py", filePath); } filePath = search_dir.absoluteFilePath("socks.py"); removePythonScriptIfExists(filePath); - QFile::copy(":/"+nova_folder+"/socks.py", filePath); + QFile::copy(":/" + nova_folder + "/socks.py", filePath); if (nova_folder == "nova") { filePath = search_dir.absoluteFilePath("fix_encoding.py"); removePythonScriptIfExists(filePath); - QFile::copy(":/"+nova_folder+"/fix_encoding.py", filePath); + QFile::copy(":/" + nova_folder + "/fix_encoding.py", filePath); } else if (nova_folder == "nova3") { filePath = search_dir.absoluteFilePath("sgmllib3.py"); removePythonScriptIfExists(filePath); - QFile::copy(":/"+nova_folder+"/sgmllib3.py", filePath); + QFile::copy(":/" + nova_folder + "/sgmllib3.py", filePath); } 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(); foreach (const QString &file, files) { QString shipped_file = shipped_subDir.absoluteFilePath(file); @@ -408,13 +423,12 @@ void SearchEngine::updateNova() { qDebug("%s copied to %s", qPrintable(shipped_file), qPrintable(dest_file)); QFile::copy(shipped_file, dest_file); } - } else { - // Copy icons - if (file.endsWith(".png")) { - if (!QFile::exists(destDir.absoluteFilePath(file))) { + } + else { + // Copy icons + if (file.endsWith(".png")) + if (!QFile::exists(destDir.absoluteFilePath(file))) QFile::copy(shipped_file, destDir.absoluteFilePath(file)); - } - } } } } @@ -422,37 +436,37 @@ void SearchEngine::updateNova() { // Slot called when search is Finished // Search can be finished for 3 reasons : // Error | Stopped by user | Finished normally -void SearchEngine::searchFinished(int exitcode, QProcess::ExitStatus) { - if (searchTimeout->isActive()) { +void SearchEngine::searchFinished(int exitcode, QProcess::ExitStatus) +{ + if (searchTimeout->isActive()) searchTimeout->stop(); - } bool useNotificationBalloons = Preferences::instance()->useProgramNotification(); - if (useNotificationBalloons && mp_mainWindow->getCurrentTabWidget() != this) { + if (useNotificationBalloons && mp_mainWindow->getCurrentTabWidget() != this) mp_mainWindow->showNotificationBaloon(tr("Search Engine"), tr("Search has finished")); - } if (exitcode) { #ifdef Q_OS_WIN activeSearchTab->status = tr("Search aborted"); #else activeSearchTab->status = tr("An error occurred during search..."); #endif - } else { + } + else { if (search_stopped) { activeSearchTab->status = tr("Search aborted"); - } else { - if (no_search_results) { + } + else { + if (no_search_results) activeSearchTab->status = tr("Search returned no results"); - } else { + else activeSearchTab->status = tr("Search has finished"); - } } } if (activeSearchTab) if (currentSearchTab == activeSearchTab) search_status->setText(activeSearchTab->status); - activeSearchTab->getCurrentLabel()->setText(tr("Results", "i.e: Search results")+QString::fromUtf8(" (")+QString::number(nb_search_results)+QString::fromUtf8("):")); - activeSearchTab->isActive = false; - activeSearchTab = 0; + activeSearchTab->getCurrentLabel()->setText(tr("Results", "i.e: Search results") + QString::fromUtf8(" (") + QString::number(nb_search_results) + QString::fromUtf8("):")); + activeSearchTab->isActive = false; + activeSearchTab = 0; search_button->setText(tr("Search")); } @@ -460,22 +474,20 @@ void SearchEngine::searchFinished(int exitcode, QProcess::ExitStatus) { // SLOT to append one line to search results list // Line is in the following form : // file url | file name | file size | nb seeds | nb leechers | Search engine url -void SearchEngine::appendSearchResult(const QString &line) { +void SearchEngine::appendSearchResult(const QString &line) +{ if (!activeSearchTab) { - if (searchProcess->state() != QProcess::NotRunning) { + if (searchProcess->state() != QProcess::NotRunning) searchProcess->terminate(); - } - if (searchTimeout->isActive()) { + if (searchTimeout->isActive()) searchTimeout->stop(); - } search_stopped = true; return; } const QStringList parts = line.split("|"); const int nb_fields = parts.size(); - if (nb_fields < NB_PLUGIN_COLUMNS-1) { //-1 because desc_link is optional + if (nb_fields < NB_PLUGIN_COLUMNS - 1) //-1 because desc_link is optional return; - } Q_ASSERT(activeSearchTab); // Add item to search result list QStandardItemModel* cur_model = activeSearchTab->getCurrentSearchListModel(); @@ -488,17 +500,15 @@ void SearchEngine::appendSearchResult(const QString &line) { cur_model->setData(cur_model->index(row, SearchSortModel::SIZE), parts.at(PL_SIZE).trimmed().toLongLong()); // Size bool ok = false; qlonglong nb_seeders = parts.at(PL_SEEDS).trimmed().toLongLong(&ok); - if (!ok || nb_seeders < 0) { + if (!ok || nb_seeders < 0) cur_model->setData(cur_model->index(row, SearchSortModel::SEEDS), -1); // Seeders - } else { + else cur_model->setData(cur_model->index(row, SearchSortModel::SEEDS), nb_seeders); // Seeders - } qlonglong nb_leechers = parts.at(PL_LEECHS).trimmed().toLongLong(&ok); - if (!ok || nb_leechers < 0) { + if (!ok || nb_leechers < 0) cur_model->setData(cur_model->index(row, SearchSortModel::LEECHS), -1); // Leechers - } else { + else cur_model->setData(cur_model->index(row, SearchSortModel::LEECHS), nb_leechers); // Leechers - } cur_model->setData(cur_model->index(row, SearchSortModel::ENGINE_URL), parts.at(PL_ENGINE_URL).trimmed()); // Engine URL // Description Link if (nb_fields == NB_PLUGIN_COLUMNS) @@ -511,16 +521,15 @@ void SearchEngine::appendSearchResult(const QString &line) { goToDescBtn->setEnabled(true); } -void SearchEngine::closeTab(int index) { +void SearchEngine::closeTab(int index) +{ // Search is run for active tab so if user decided to close it, then stop search if (activeSearchTab && index == tabWidget->indexOf(activeSearchTab)) { qDebug("Closed active search Tab"); - if (searchProcess->state() != QProcess::NotRunning) { + if (searchProcess->state() != QProcess::NotRunning) searchProcess->terminate(); - } - if (searchTimeout->isActive()) { + if (searchTimeout->isActive()) searchTimeout->stop(); - } search_stopped = true; if (currentSearchTab == activeSearchTab) currentSearchTab = 0; activeSearchTab = 0; @@ -533,7 +542,8 @@ void SearchEngine::closeTab(int index) { } // Download selected items in search results list -void SearchEngine::on_download_button_clicked() { +void SearchEngine::on_download_button_clicked() +{ //QModelIndexList selectedIndexes = currentSearchTab->getCurrentTreeView()->selectionModel()->selectedIndexes(); QModelIndexList selectedIndexes = all_tab.at(tabWidget->currentIndex())->getCurrentTreeView()->selectionModel()->selectedIndexes(); foreach (const QModelIndex &index, selectedIndexes) { @@ -563,7 +573,6 @@ void SearchEngine::on_goToDescBtn_clicked() inline void SearchEngine::allTabsSetActiveState(bool newState) { - foreach(SearchTab *tab, all_tab) { + foreach(SearchTab *tab, all_tab) tab->isActive = newState; - } }