From 2d0099238a1ccb83d9311ba813f0e30b919af9e3 Mon Sep 17 00:00:00 2001 From: buinsky Date: Sat, 20 Dec 2014 20:53:58 +0300 Subject: [PATCH] Follow project coding style. Issue #2192. --- src/mainwindow.cpp | 2463 +++++++++++++++++++++++--------------------- src/mainwindow.h | 251 ++--- 2 files changed, 1389 insertions(+), 1325 deletions(-) diff --git a/src/mainwindow.cpp b/src/mainwindow.cpp index 99cf21a8a..9d0b93484 100755 --- a/src/mainwindow.cpp +++ b/src/mainwindow.cpp @@ -97,1351 +97,1410 @@ using namespace libtorrent; #define PREVENT_SUSPEND_INTERVAL 60000 /***************************************************** - * * - * GUI * - * * - *****************************************************/ +* * +* GUI * +* * +*****************************************************/ // Constructor -MainWindow::MainWindow(QWidget *parent, const QStringList& torrentCmdLine) : QMainWindow(parent), m_posInitialized(false), force_exit(false), unlockDlgShowing(false) +MainWindow::MainWindow(QWidget *parent, const QStringList& torrentCmdLine): QMainWindow(parent), m_posInitialized(false), force_exit(false), unlockDlgShowing(false) #ifdef Q_OS_WIN -, has_python(false) + , has_python(false) #endif { - setupUi(this); + setupUi(this); - Preferences* const pref = Preferences::instance(); - ui_locked = pref->isUILocked(); - setWindowTitle(QString("qBittorrent %1").arg(QString::fromUtf8(VERSION))); - displaySpeedInTitle = pref->speedInTitleBar(); - // Clean exit on log out - connect(qApp, SIGNAL(aboutToQuit()), this, SLOT(shutdownCleanUp()), Qt::DirectConnection); - // Setting icons + Preferences* const pref = Preferences::instance(); + ui_locked = pref->isUILocked(); + setWindowTitle(QString("qBittorrent %1").arg(QString::fromUtf8(VERSION))); + displaySpeedInTitle = pref->speedInTitleBar(); + // Clean exit on log out + connect(qApp, SIGNAL(aboutToQuit()), this, SLOT(shutdownCleanUp()), Qt::DirectConnection); + // Setting icons #if (defined(Q_OS_UNIX) && !defined(Q_OS_MAC)) - if (Preferences::instance()->useSystemIconTheme()) - setWindowIcon(QIcon::fromTheme("qbittorrent", QIcon(QString::fromUtf8(":/Icons/skin/qbittorrent32.png")))); - else + if (Preferences::instance()->useSystemIconTheme()) + setWindowIcon(QIcon::fromTheme("qbittorrent", QIcon(QString::fromUtf8(":/Icons/skin/qbittorrent32.png")))); + else #endif setWindowIcon(QIcon(QString::fromUtf8(":/Icons/skin/qbittorrent32.png"))); - actionOpen->setIcon(IconProvider::instance()->getIcon("list-add")); - actionDownload_from_URL->setIcon(IconProvider::instance()->getIcon("insert-link")); - actionSet_upload_limit->setIcon(QIcon(QString::fromUtf8(":/Icons/skin/seeding.png"))); - actionSet_download_limit->setIcon(QIcon(QString::fromUtf8(":/Icons/skin/download.png"))); - actionSet_global_upload_limit->setIcon(QIcon(QString::fromUtf8(":/Icons/skin/seeding.png"))); - actionSet_global_download_limit->setIcon(QIcon(QString::fromUtf8(":/Icons/skin/download.png"))); - actionCreate_torrent->setIcon(IconProvider::instance()->getIcon("document-edit")); - actionAbout->setIcon(IconProvider::instance()->getIcon("help-about")); - actionStatistics->setIcon(IconProvider::instance()->getIcon("view-statistics")); - actionBugReport->setIcon(IconProvider::instance()->getIcon("tools-report-bug")); - actionDecreasePriority->setIcon(IconProvider::instance()->getIcon("go-down")); - actionBottomPriority->setIcon(IconProvider::instance()->getIcon("go-bottom")); - actionDelete->setIcon(IconProvider::instance()->getIcon("list-remove")); - actionDocumentation->setIcon(IconProvider::instance()->getIcon("help-contents")); - actionDonate_money->setIcon(IconProvider::instance()->getIcon("wallet-open")); - actionExit->setIcon(IconProvider::instance()->getIcon("application-exit")); - actionIncreasePriority->setIcon(IconProvider::instance()->getIcon("go-up")); - actionTopPriority->setIcon(IconProvider::instance()->getIcon("go-top")); - actionLock_qBittorrent->setIcon(IconProvider::instance()->getIcon("object-locked")); - actionOptions->setIcon(IconProvider::instance()->getIcon("preferences-system")); - actionPause->setIcon(IconProvider::instance()->getIcon("media-playback-pause")); - actionPause_All->setIcon(IconProvider::instance()->getIcon("media-playback-pause")); - actionStart->setIcon(IconProvider::instance()->getIcon("media-playback-start")); - actionStart_All->setIcon(IconProvider::instance()->getIcon("media-playback-start")); - action_Import_Torrent->setIcon(IconProvider::instance()->getIcon("document-import")); - menuAuto_Shutdown_on_downloads_completion->setIcon(IconProvider::instance()->getIcon("application-exit")); - - QMenu *startAllMenu = new QMenu(this); - startAllMenu->addAction(actionStart_All); - actionStart->setMenu(startAllMenu); - QMenu *pauseAllMenu = new QMenu(this); - pauseAllMenu->addAction(actionPause_All); - actionPause->setMenu(pauseAllMenu); - QMenu *lockMenu = new QMenu(this); - QAction *defineUiLockPasswdAct = lockMenu->addAction(tr("Set the password...")); - connect(defineUiLockPasswdAct, SIGNAL(triggered()), this, SLOT(defineUILockPassword())); - QAction *clearUiLockPasswdAct = lockMenu->addAction(tr("Clear the password")); - connect(clearUiLockPasswdAct, SIGNAL(triggered()), this, SLOT(clearUILockPassword())); - actionLock_qBittorrent->setMenu(lockMenu); - // Creating Bittorrent session - connect(QBtSession::instance(), SIGNAL(fullDiskError(QTorrentHandle, QString)), this, SLOT(fullDiskError(QTorrentHandle, QString))); - connect(QBtSession::instance(), SIGNAL(finishedTorrent(QTorrentHandle)), this, SLOT(finishedTorrent(QTorrentHandle))); - connect(QBtSession::instance(), SIGNAL(trackerAuthenticationRequired(QTorrentHandle)), this, SLOT(trackerAuthenticationRequired(QTorrentHandle))); - connect(QBtSession::instance(), SIGNAL(newDownloadedTorrent(QString, QString)), this, SLOT(processDownloadedFiles(QString, QString))); - connect(QBtSession::instance(), SIGNAL(newMagnetLink(QString)), this, SLOT(processNewMagnetLink(QString))); - connect(QBtSession::instance(), SIGNAL(downloadFromUrlFailure(QString, QString)), this, SLOT(handleDownloadFromUrlFailure(QString, QString))); - connect(QBtSession::instance(), SIGNAL(alternativeSpeedsModeChanged(bool)), this, SLOT(updateAltSpeedsBtn(bool))); - connect(QBtSession::instance(), SIGNAL(recursiveTorrentDownloadPossible(QTorrentHandle)), this, SLOT(askRecursiveTorrentDownloadConfirmation(QTorrentHandle))); + actionOpen->setIcon(IconProvider::instance()->getIcon("list-add")); + actionDownload_from_URL->setIcon(IconProvider::instance()->getIcon("insert-link")); + actionSet_upload_limit->setIcon(QIcon(QString::fromUtf8(":/Icons/skin/seeding.png"))); + actionSet_download_limit->setIcon(QIcon(QString::fromUtf8(":/Icons/skin/download.png"))); + actionSet_global_upload_limit->setIcon(QIcon(QString::fromUtf8(":/Icons/skin/seeding.png"))); + actionSet_global_download_limit->setIcon(QIcon(QString::fromUtf8(":/Icons/skin/download.png"))); + actionCreate_torrent->setIcon(IconProvider::instance()->getIcon("document-edit")); + actionAbout->setIcon(IconProvider::instance()->getIcon("help-about")); + actionStatistics->setIcon(IconProvider::instance()->getIcon("view-statistics")); + actionBugReport->setIcon(IconProvider::instance()->getIcon("tools-report-bug")); + actionDecreasePriority->setIcon(IconProvider::instance()->getIcon("go-down")); + actionBottomPriority->setIcon(IconProvider::instance()->getIcon("go-bottom")); + actionDelete->setIcon(IconProvider::instance()->getIcon("list-remove")); + actionDocumentation->setIcon(IconProvider::instance()->getIcon("help-contents")); + actionDonate_money->setIcon(IconProvider::instance()->getIcon("wallet-open")); + actionExit->setIcon(IconProvider::instance()->getIcon("application-exit")); + actionIncreasePriority->setIcon(IconProvider::instance()->getIcon("go-up")); + actionTopPriority->setIcon(IconProvider::instance()->getIcon("go-top")); + actionLock_qBittorrent->setIcon(IconProvider::instance()->getIcon("object-locked")); + actionOptions->setIcon(IconProvider::instance()->getIcon("preferences-system")); + actionPause->setIcon(IconProvider::instance()->getIcon("media-playback-pause")); + actionPause_All->setIcon(IconProvider::instance()->getIcon("media-playback-pause")); + actionStart->setIcon(IconProvider::instance()->getIcon("media-playback-start")); + actionStart_All->setIcon(IconProvider::instance()->getIcon("media-playback-start")); + action_Import_Torrent->setIcon(IconProvider::instance()->getIcon("document-import")); + menuAuto_Shutdown_on_downloads_completion->setIcon(IconProvider::instance()->getIcon("application-exit")); + + QMenu *startAllMenu = new QMenu(this); + startAllMenu->addAction(actionStart_All); + actionStart->setMenu(startAllMenu); + QMenu *pauseAllMenu = new QMenu(this); + pauseAllMenu->addAction(actionPause_All); + actionPause->setMenu(pauseAllMenu); + QMenu *lockMenu = new QMenu(this); + QAction *defineUiLockPasswdAct = lockMenu->addAction(tr("Set the password...")); + connect(defineUiLockPasswdAct, SIGNAL(triggered()), this, SLOT(defineUILockPassword())); + QAction *clearUiLockPasswdAct = lockMenu->addAction(tr("Clear the password")); + connect(clearUiLockPasswdAct, SIGNAL(triggered()), this, SLOT(clearUILockPassword())); + actionLock_qBittorrent->setMenu(lockMenu); + // Creating Bittorrent session + connect(QBtSession::instance(), SIGNAL(fullDiskError(QTorrentHandle, QString)), this, SLOT(fullDiskError(QTorrentHandle, QString))); + connect(QBtSession::instance(), SIGNAL(finishedTorrent(QTorrentHandle)), this, SLOT(finishedTorrent(QTorrentHandle))); + connect(QBtSession::instance(), SIGNAL(trackerAuthenticationRequired(QTorrentHandle)), this, SLOT(trackerAuthenticationRequired(QTorrentHandle))); + connect(QBtSession::instance(), SIGNAL(newDownloadedTorrent(QString, QString)), this, SLOT(processDownloadedFiles(QString, QString))); + connect(QBtSession::instance(), SIGNAL(newMagnetLink(QString)), this, SLOT(processNewMagnetLink(QString))); + connect(QBtSession::instance(), SIGNAL(downloadFromUrlFailure(QString, QString)), this, SLOT(handleDownloadFromUrlFailure(QString, QString))); + connect(QBtSession::instance(), SIGNAL(alternativeSpeedsModeChanged(bool)), this, SLOT(updateAltSpeedsBtn(bool))); + connect(QBtSession::instance(), SIGNAL(recursiveTorrentDownloadPossible(QTorrentHandle)), this, SLOT(askRecursiveTorrentDownloadConfirmation(QTorrentHandle))); #ifdef Q_OS_MAC - connect(static_cast(qApp), SIGNAL(newFileOpenMacEvent(QString)), this, SLOT(processParams(QString))); + connect(static_cast(qApp), SIGNAL(newFileOpenMacEvent(QString)), this, SLOT(processParams(QString))); #endif - qDebug("create tabWidget"); - tabs = new HidableTabWidget(); - connect(tabs, SIGNAL(currentChanged(int)), this, SLOT(tab_changed(int))); - vSplitter = new QSplitter(Qt::Horizontal); - //vSplitter->setChildrenCollapsible(false); - hSplitter = new QSplitter(Qt::Vertical); - hSplitter->setChildrenCollapsible(false); - hSplitter->setContentsMargins(0, 4, 0, 0); - - // Name filter - search_filter = new LineEdit(); - searchFilterAct = toolBar->insertWidget(actionLock_qBittorrent, search_filter); - search_filter->setPlaceholderText(tr("Filter torrent list...")); - search_filter->setFixedWidth(200); - QWidget *spacer = new QWidget(this); - spacer->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed); - toolBar->insertWidget(searchFilterAct, spacer); - - // Transfer List tab - transferList = new TransferListWidget(hSplitter, this, QBtSession::instance()); - properties = new PropertiesWidget(hSplitter, this, transferList); - transferListFilters = new TransferListFiltersWidget(vSplitter, transferList); - hSplitter->addWidget(transferList); - hSplitter->addWidget(properties); - vSplitter->addWidget(transferListFilters); - vSplitter->addWidget(hSplitter); - vSplitter->setCollapsible(0, true); - vSplitter->setCollapsible(1, false); - tabs->addTab(vSplitter, IconProvider::instance()->getIcon("folder-remote"), tr("Transfers")); - - connect(search_filter, SIGNAL(textChanged(QString)), transferList, SLOT(applyNameFilter(QString))); - connect(hSplitter, SIGNAL(splitterMoved(int, int)), this, SLOT(writeSettings())); - connect(vSplitter, SIGNAL(splitterMoved(int, int)), this, SLOT(writeSettings())); - - vboxLayout->addWidget(tabs); - - prioSeparator = toolBar->insertSeparator(actionBottomPriority); - prioSeparatorMenu = menu_Edit->insertSeparator(actionTopPriority); - - // Transfer list slots - connect(actionStart, SIGNAL(triggered()), transferList, SLOT(startSelectedTorrents())); - connect(actionStart_All, SIGNAL(triggered()), QBtSession::instance(), SLOT(resumeAllTorrents())); - connect(actionPause, SIGNAL(triggered()), transferList, SLOT(pauseSelectedTorrents())); - connect(actionPause_All, SIGNAL(triggered()), QBtSession::instance(), SLOT(pauseAllTorrents())); - connect(actionDelete, SIGNAL(triggered()), transferList, SLOT(deleteSelectedTorrents())); - connect(actionTopPriority, SIGNAL(triggered()), transferList, SLOT(topPrioSelectedTorrents())); - connect(actionIncreasePriority, SIGNAL(triggered()), transferList, SLOT(increasePrioSelectedTorrents())); - connect(actionDecreasePriority, SIGNAL(triggered()), transferList, SLOT(decreasePrioSelectedTorrents())); - connect(actionBottomPriority, SIGNAL(triggered()), transferList, SLOT(bottomPrioSelectedTorrents())); - connect(actionToggleVisibility, SIGNAL(triggered()), this, SLOT(toggleVisibility())); - connect(actionMinimize, SIGNAL(triggered()), SLOT(minimizeWindow())); + qDebug("create tabWidget"); + tabs = new HidableTabWidget(); + connect(tabs, SIGNAL(currentChanged(int)), this, SLOT(tab_changed(int))); + vSplitter = new QSplitter(Qt::Horizontal); + //vSplitter->setChildrenCollapsible(false); + hSplitter = new QSplitter(Qt::Vertical); + hSplitter->setChildrenCollapsible(false); + hSplitter->setContentsMargins(0, 4, 0, 0); + + // Name filter + search_filter = new LineEdit(); + searchFilterAct = toolBar->insertWidget(actionLock_qBittorrent, search_filter); + search_filter->setPlaceholderText(tr("Filter torrent list...")); + search_filter->setFixedWidth(200); + QWidget *spacer = new QWidget(this); + spacer->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed); + toolBar->insertWidget(searchFilterAct, spacer); + + // Transfer List tab + transferList = new TransferListWidget(hSplitter, this, QBtSession::instance()); + properties = new PropertiesWidget(hSplitter, this, transferList); + transferListFilters = new TransferListFiltersWidget(vSplitter, transferList); + hSplitter->addWidget(transferList); + hSplitter->addWidget(properties); + vSplitter->addWidget(transferListFilters); + vSplitter->addWidget(hSplitter); + vSplitter->setCollapsible(0, true); + vSplitter->setCollapsible(1, false); + tabs->addTab(vSplitter, IconProvider::instance()->getIcon("folder-remote"), tr("Transfers")); + + connect(search_filter, SIGNAL(textChanged(QString)), transferList, SLOT(applyNameFilter(QString))); + connect(hSplitter, SIGNAL(splitterMoved(int, int)), this, SLOT(writeSettings())); + connect(vSplitter, SIGNAL(splitterMoved(int, int)), this, SLOT(writeSettings())); + + vboxLayout->addWidget(tabs); + + prioSeparator = toolBar->insertSeparator(actionBottomPriority); + prioSeparatorMenu = menu_Edit->insertSeparator(actionTopPriority); + + // Transfer list slots + connect(actionStart, SIGNAL(triggered()), transferList, SLOT(startSelectedTorrents())); + connect(actionStart_All, SIGNAL(triggered()), QBtSession::instance(), SLOT(resumeAllTorrents())); + connect(actionPause, SIGNAL(triggered()), transferList, SLOT(pauseSelectedTorrents())); + connect(actionPause_All, SIGNAL(triggered()), QBtSession::instance(), SLOT(pauseAllTorrents())); + connect(actionDelete, SIGNAL(triggered()), transferList, SLOT(deleteSelectedTorrents())); + connect(actionTopPriority, SIGNAL(triggered()), transferList, SLOT(topPrioSelectedTorrents())); + connect(actionIncreasePriority, SIGNAL(triggered()), transferList, SLOT(increasePrioSelectedTorrents())); + connect(actionDecreasePriority, SIGNAL(triggered()), transferList, SLOT(decreasePrioSelectedTorrents())); + connect(actionBottomPriority, SIGNAL(triggered()), transferList, SLOT(bottomPrioSelectedTorrents())); + connect(actionToggleVisibility, SIGNAL(triggered()), this, SLOT(toggleVisibility())); + connect(actionMinimize, SIGNAL(triggered()), SLOT(minimizeWindow())); #if defined(Q_OS_WIN) || defined(Q_OS_MAC) - programUpdateTimer.setInterval(60*60*1000); - programUpdateTimer.setSingleShot(true); - connect(&programUpdateTimer, SIGNAL(timeout()), SLOT(checkProgramUpdate())); - connect(actionCheck_for_updates, SIGNAL(triggered()), SLOT(checkProgramUpdate())); + programUpdateTimer.setInterval(60 * 60 * 1000); + programUpdateTimer.setSingleShot(true); + connect(&programUpdateTimer, SIGNAL(timeout()), SLOT(checkProgramUpdate())); + connect(actionCheck_for_updates, SIGNAL(triggered()), SLOT(checkProgramUpdate())); #else - actionCheck_for_updates->setVisible(false); + actionCheck_for_updates->setVisible(false); #endif - m_pwr = new PowerManagement(this); - preventTimer = new QTimer(this); - connect(preventTimer, SIGNAL(timeout()), SLOT(checkForActiveTorrents())); - - // Configure BT session according to options - loadPreferences(false); - - // Start connection checking timer - guiUpdater = new QTimer(this); - connect(guiUpdater, SIGNAL(timeout()), this, SLOT(updateGUI())); - guiUpdater->start(2000); - // Accept drag 'n drops - setAcceptDrops(true); - createKeyboardShortcuts(); - // Create status bar - status_bar = new StatusBar(QMainWindow::statusBar()); - connect(status_bar->connectionStatusButton(), SIGNAL(clicked()), SLOT(showConnectionSettings())); - connect(actionUse_alternative_speed_limits, SIGNAL(triggered()), status_bar, SLOT(toggleAlternativeSpeeds())); + m_pwr = new PowerManagement(this); + preventTimer = new QTimer(this); + connect(preventTimer, SIGNAL(timeout()), SLOT(checkForActiveTorrents())); + + // Configure BT session according to options + loadPreferences(false); + + // Start connection checking timer + guiUpdater = new QTimer(this); + connect(guiUpdater, SIGNAL(timeout()), this, SLOT(updateGUI())); + guiUpdater->start(2000); + // Accept drag 'n drops + setAcceptDrops(true); + createKeyboardShortcuts(); + // Create status bar + status_bar = new StatusBar(QMainWindow::statusBar()); + connect(status_bar->connectionStatusButton(), SIGNAL(clicked()), SLOT(showConnectionSettings())); + connect(actionUse_alternative_speed_limits, SIGNAL(triggered()), status_bar, SLOT(toggleAlternativeSpeeds())); #ifdef Q_OS_MAC - setUnifiedTitleAndToolBarOnMac(true); + setUnifiedTitleAndToolBarOnMac(true); #endif - // View settings - actionTop_tool_bar->setChecked(pref->isToolbarDisplayed()); - actionSpeed_in_title_bar->setChecked(pref->speedInTitleBar()); - actionRSS_Reader->setChecked(pref->isRSSEnabled()); - actionSearch_engine->setChecked(pref->isSearchEnabled()); - actionExecution_Logs->setChecked(pref->isExecutionLogEnabled()); - displayRSSTab(actionRSS_Reader->isChecked()); - on_actionExecution_Logs_triggered(actionExecution_Logs->isChecked()); - if (actionSearch_engine->isChecked()) - QTimer::singleShot(0, this, SLOT(on_actionSearch_engine_triggered())); - - // Auto shutdown actions - QActionGroup * autoShutdownGroup = new QActionGroup(this); - autoShutdownGroup->setExclusive(true); - autoShutdownGroup->addAction(actionAutoShutdown_Disabled); - autoShutdownGroup->addAction(actionAutoExit_qBittorrent); - autoShutdownGroup->addAction(actionAutoShutdown_system); - autoShutdownGroup->addAction(actionAutoSuspend_system); - autoShutdownGroup->addAction(actionAutoHibernate_system); + // View settings + actionTop_tool_bar->setChecked(pref->isToolbarDisplayed()); + actionSpeed_in_title_bar->setChecked(pref->speedInTitleBar()); + actionRSS_Reader->setChecked(pref->isRSSEnabled()); + actionSearch_engine->setChecked(pref->isSearchEnabled()); + actionExecution_Logs->setChecked(pref->isExecutionLogEnabled()); + displayRSSTab(actionRSS_Reader->isChecked()); + on_actionExecution_Logs_triggered(actionExecution_Logs->isChecked()); + if (actionSearch_engine->isChecked()) + QTimer::singleShot(0, this, SLOT(on_actionSearch_engine_triggered())); + + // Auto shutdown actions + QActionGroup * autoShutdownGroup = new QActionGroup(this); + autoShutdownGroup->setExclusive(true); + autoShutdownGroup->addAction(actionAutoShutdown_Disabled); + autoShutdownGroup->addAction(actionAutoExit_qBittorrent); + autoShutdownGroup->addAction(actionAutoShutdown_system); + autoShutdownGroup->addAction(actionAutoSuspend_system); + autoShutdownGroup->addAction(actionAutoHibernate_system); #if (!defined(Q_OS_UNIX) || defined(Q_OS_MAC)) || defined(QT_DBUS_LIB) - actionAutoShutdown_system->setChecked(pref->shutdownWhenDownloadsComplete()); - actionAutoSuspend_system->setChecked(pref->suspendWhenDownloadsComplete()); - actionAutoHibernate_system->setChecked(pref->hibernateWhenDownloadsComplete()); + actionAutoShutdown_system->setChecked(pref->shutdownWhenDownloadsComplete()); + actionAutoSuspend_system->setChecked(pref->suspendWhenDownloadsComplete()); + actionAutoHibernate_system->setChecked(pref->hibernateWhenDownloadsComplete()); #else - actionAutoShutdown_system->setDisabled(true); - actionAutoSuspend_system->setDisabled(true); - actionAutoHibernate_system->setDisabled(true); + actionAutoShutdown_system->setDisabled(true); + actionAutoSuspend_system->setDisabled(true); + actionAutoHibernate_system->setDisabled(true); #endif - actionAutoExit_qBittorrent->setChecked(pref->shutdownqBTWhenDownloadsComplete()); + actionAutoExit_qBittorrent->setChecked(pref->shutdownqBTWhenDownloadsComplete()); - if (!autoShutdownGroup->checkedAction()) - actionAutoShutdown_Disabled->setChecked(true); + if (!autoShutdownGroup->checkedAction()) + actionAutoShutdown_Disabled->setChecked(true); - // Load Window state and sizes - readSettings(); + // Load Window state and sizes + readSettings(); - if (systrayIcon) { - if (!(pref->startMinimized() || ui_locked)) { - show(); - activateWindow(); - raise(); + if (systrayIcon) { + if (!(pref->startMinimized() || ui_locked)) { + show(); + activateWindow(); + raise(); + } } - } - properties->readSettings(); + properties->readSettings(); - // Start watching the executable for updates - executable_watcher = new QFileSystemWatcher(); - connect(executable_watcher, SIGNAL(fileChanged(QString)), this, SLOT(notifyOfUpdate(QString))); - executable_watcher->addPath(qApp->applicationFilePath()); + // Start watching the executable for updates + executable_watcher = new QFileSystemWatcher(); + connect(executable_watcher, SIGNAL(fileChanged(QString)), this, SLOT(notifyOfUpdate(QString))); + executable_watcher->addPath(qApp->applicationFilePath()); - // Resume unfinished torrents - QBtSession::instance()->startUpTorrents(); - // Add torrent given on command line - processParams(torrentCmdLine); + // Resume unfinished torrents + QBtSession::instance()->startUpTorrents(); + // Add torrent given on command line + processParams(torrentCmdLine); - // Populate the transfer list - transferList->getSourceModel()->populate(); - transferList->setFocus(); + // Populate the transfer list + transferList->getSourceModel()->populate(); + transferList->setFocus(); - // Update the number of torrents (tab) - updateNbTorrents(); - connect(transferList->getSourceModel(), SIGNAL(rowsInserted(QModelIndex, int, int)), this, SLOT(updateNbTorrents())); - connect(transferList->getSourceModel(), SIGNAL(rowsRemoved(QModelIndex, int, int)), this, SLOT(updateNbTorrents())); + // Update the number of torrents (tab) + updateNbTorrents(); + connect(transferList->getSourceModel(), SIGNAL(rowsInserted(QModelIndex, int, int)), this, SLOT(updateNbTorrents())); + connect(transferList->getSourceModel(), SIGNAL(rowsRemoved(QModelIndex, int, int)), this, SLOT(updateNbTorrents())); - qDebug("GUI Built"); + qDebug("GUI Built"); #ifdef Q_OS_WIN - if (!pref->neverCheckFileAssoc() && (!Preferences::isTorrentFileAssocSet() || !Preferences::isMagnetLinkAssocSet())) { - if (QMessageBox::question(0, tr("Torrent file association"), - tr("qBittorrent is not the default application to open torrent files or Magnet links.\nDo you want to associate qBittorrent to torrent files and Magnet links?"), - QMessageBox::Yes|QMessageBox::No, QMessageBox::Yes) == QMessageBox::Yes) { - Preferences::setTorrentFileAssoc(true); - Preferences::setMagnetLinkAssoc(true); - } else { - pref->setNeverCheckFileAssoc(); + if (!pref->neverCheckFileAssoc() && (!Preferences::isTorrentFileAssocSet() || !Preferences::isMagnetLinkAssocSet())) { + if (QMessageBox::question(0, tr("Torrent file association"), + tr("qBittorrent is not the default application to open torrent files or Magnet links.\nDo you want to associate qBittorrent to torrent files and Magnet links?"), + QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes) == QMessageBox::Yes) { + Preferences::setTorrentFileAssoc(true); + Preferences::setMagnetLinkAssoc(true); + } + else { + pref->setNeverCheckFileAssoc(); + } } - } #endif #ifdef Q_OS_MAC - qt_mac_set_dock_menu(getTrayIconMenu()); + qt_mac_set_dock_menu(getTrayIconMenu()); #endif - // Make sure the Window is visible if we don't have a tray icon - if (!systrayIcon) { - if (pref->startMinimized()) { - showMinimized(); - } else { - show(); - activateWindow(); - raise(); + // Make sure the Window is visible if we don't have a tray icon + if (!systrayIcon) { + if (pref->startMinimized()) { + showMinimized(); + } + else { + show(); + activateWindow(); + raise(); + } } - } -} - -void MainWindow::shutdownCleanUp() { - qDebug("GUI destruction"); - hide(); - guiUpdater->stop(); - status_bar->stopTimer(); - m_pwr->setActivityState(false); - QBtSession::drop(); - // Save window size, columns size - writeSettings(); +} + +void MainWindow::shutdownCleanUp() +{ + qDebug("GUI destruction"); + hide(); + guiUpdater->stop(); + status_bar->stopTimer(); + m_pwr->setActivityState(false); + QBtSession::drop(); + // Save window size, columns size + writeSettings(); #ifdef Q_OS_MAC - // Workaround to avoid bug http://bugreports.qt.nokia.com/browse/QTBUG-7305 - setUnifiedTitleAndToolBarOnMac(false); + // Workaround to avoid bug http://bugreports.qt.nokia.com/browse/QTBUG-7305 + setUnifiedTitleAndToolBarOnMac(false); #endif - disconnect(tabs, SIGNAL(currentChanged(int)), this, SLOT(tab_changed(int))); - // Delete other GUI objects - if (executable_watcher) - delete executable_watcher; - delete status_bar; - delete search_filter; - delete transferList; - delete guiUpdater; - if (createTorrentDlg) - delete createTorrentDlg; - if (m_executionLog) - delete m_executionLog; - if (aboutDlg) - delete aboutDlg; - if (statsDlg) - delete statsDlg; - if (options) - delete options; - if (downloadFromURLDialog) - delete downloadFromURLDialog; - if (rssWidget) - delete rssWidget; - if (searchEngine) - delete searchEngine; - delete transferListFilters; - delete properties; - delete hSplitter; - delete vSplitter; - if (systrayCreator) - delete systrayCreator; - if (systrayIcon) - delete systrayIcon; - if (myTrayIconMenu) - delete myTrayIconMenu; - delete tabs; - // Keyboard shortcuts - delete switchSearchShortcut; - delete switchSearchShortcut2; - delete switchTransferShortcut; - delete switchRSSShortcut; - IconProvider::drop(); - Preferences::drop(); - qDebug("Finished GUI destruction"); -} - -void MainWindow::defineUILockPassword() { - QString old_pass_md5 = Preferences::instance()->getUILockPasswordMD5(); - if (old_pass_md5.isNull()) old_pass_md5 = ""; - bool ok = false; - QString new_clear_password = AutoExpandableDialog::getText(this, tr("UI lock password"), tr("Please type the UI lock password:"), QLineEdit::Password, old_pass_md5, &ok); - if (ok) { - new_clear_password = new_clear_password.trimmed(); - if (new_clear_password.size() < 3) { - QMessageBox::warning(this, tr("Invalid password"), tr("The password should contain at least 3 characters")); - return; - } - if (new_clear_password != old_pass_md5) { - Preferences::instance()->setUILockPassword(new_clear_password); + disconnect(tabs, SIGNAL(currentChanged(int)), this, SLOT(tab_changed(int))); + // Delete other GUI objects + if (executable_watcher) + delete executable_watcher; + delete status_bar; + delete search_filter; + delete transferList; + delete guiUpdater; + if (createTorrentDlg) + delete createTorrentDlg; + if (m_executionLog) + delete m_executionLog; + if (aboutDlg) + delete aboutDlg; + if (statsDlg) + delete statsDlg; + if (options) + delete options; + if (downloadFromURLDialog) + delete downloadFromURLDialog; + if (rssWidget) + delete rssWidget; + if (searchEngine) + delete searchEngine; + delete transferListFilters; + delete properties; + delete hSplitter; + delete vSplitter; + if (systrayCreator) + delete systrayCreator; + if (systrayIcon) + delete systrayIcon; + if (myTrayIconMenu) + delete myTrayIconMenu; + delete tabs; + // Keyboard shortcuts + delete switchSearchShortcut; + delete switchSearchShortcut2; + delete switchTransferShortcut; + delete switchRSSShortcut; + IconProvider::drop(); + Preferences::drop(); + qDebug("Finished GUI destruction"); +} + +void MainWindow::defineUILockPassword() +{ + QString old_pass_md5 = Preferences::instance()->getUILockPasswordMD5(); + if (old_pass_md5.isNull()) old_pass_md5 = ""; + bool ok = false; + QString new_clear_password = AutoExpandableDialog::getText(this, tr("UI lock password"), tr("Please type the UI lock password:"), QLineEdit::Password, old_pass_md5, &ok); + if (ok) { + new_clear_password = new_clear_password.trimmed(); + if (new_clear_password.size() < 3) { + QMessageBox::warning(this, tr("Invalid password"), tr("The password should contain at least 3 characters")); + return; + } + if (new_clear_password != old_pass_md5) + Preferences::instance()->setUILockPassword(new_clear_password); + QMessageBox::information(this, tr("Password update"), tr("The UI lock password has been successfully updated")); } - QMessageBox::information(this, tr("Password update"), tr("The UI lock password has been successfully updated")); - } } -void MainWindow::clearUILockPassword() { - QMessageBox::StandardButton answer = QMessageBox::question(this, tr("Clear the password"), tr("Are you sure you want to clear the password?"), QMessageBox::Yes|QMessageBox::No, QMessageBox::No); - if (answer == QMessageBox::Yes) - Preferences::instance()->clearUILockPassword(); +void MainWindow::clearUILockPassword() +{ + QMessageBox::StandardButton answer = QMessageBox::question(this, tr("Clear the password"), tr("Are you sure you want to clear the password?"), QMessageBox::Yes | QMessageBox::No, QMessageBox::No); + if (answer == QMessageBox::Yes) + Preferences::instance()->clearUILockPassword(); } -void MainWindow::on_actionLock_qBittorrent_triggered() { - Preferences* const pref = Preferences::instance(); - // Check if there is a password - if (pref->getUILockPasswordMD5().isEmpty()) { - // Ask for a password - bool ok = false; - QString clear_password = AutoExpandableDialog::getText(this, tr("UI lock password"), tr("Please type the UI lock password:"), QLineEdit::Password, "", &ok); - if (!ok) return; - pref->setUILockPassword(clear_password); - } - // Lock the interface - ui_locked = true; - pref->setUILocked(true); - myTrayIconMenu->setEnabled(false); - hide(); -} - -void MainWindow::displayRSSTab(bool enable) { - if (enable) { - // RSS tab - if (!rssWidget) { - rssWidget = new RSSImp(tabs); - int index_tab = tabs->addTab(rssWidget, tr("RSS")); - tabs->setTabIcon(index_tab, IconProvider::instance()->getIcon("application-rss+xml")); - } - } else { - if (rssWidget) { - delete rssWidget; +void MainWindow::on_actionLock_qBittorrent_triggered() +{ + Preferences* const pref = Preferences::instance(); + // Check if there is a password + if (pref->getUILockPasswordMD5().isEmpty()) { + // Ask for a password + bool ok = false; + QString clear_password = AutoExpandableDialog::getText(this, tr("UI lock password"), tr("Please type the UI lock password:"), QLineEdit::Password, "", &ok); + if (!ok) return; + pref->setUILockPassword(clear_password); } - } + // Lock the interface + ui_locked = true; + pref->setUILocked(true); + myTrayIconMenu->setEnabled(false); + hide(); } -void MainWindow::displaySearchTab(bool enable) { - Preferences::instance()->setSearchEnabled(enable); - if (enable) { - // RSS tab - if (!searchEngine) { - searchEngine = new SearchEngine(this); - tabs->insertTab(1, searchEngine, IconProvider::instance()->getIcon("edit-find"), tr("Search")); +void MainWindow::displayRSSTab(bool enable) +{ + if (enable) { + // RSS tab + if (!rssWidget) { + rssWidget = new RSSImp(tabs); + int index_tab = tabs->addTab(rssWidget, tr("RSS")); + tabs->setTabIcon(index_tab, IconProvider::instance()->getIcon("application-rss+xml")); + } } - } else { - if (searchEngine) { - delete searchEngine; + else if (rssWidget) + delete rssWidget; + +} + +void MainWindow::displaySearchTab(bool enable) +{ + Preferences::instance()->setSearchEnabled(enable); + if (enable) { + // RSS tab + if (!searchEngine) { + searchEngine = new SearchEngine(this); + tabs->insertTab(1, searchEngine, IconProvider::instance()->getIcon("edit-find"), tr("Search")); + } } - } + else if (searchEngine) + delete searchEngine; + } -void MainWindow::updateNbTorrents() { - tabs->setTabText(0, tr("Transfers (%1)").arg(transferList->getSourceModel()->rowCount())); +void MainWindow::updateNbTorrents() +{ + tabs->setTabText(0, tr("Transfers (%1)").arg(transferList->getSourceModel()->rowCount())); } -void MainWindow::on_actionWebsite_triggered() const { - QDesktopServices::openUrl(QUrl(QString::fromUtf8("http://www.qbittorrent.org"))); +void MainWindow::on_actionWebsite_triggered() const +{ + QDesktopServices::openUrl(QUrl(QString::fromUtf8("http://www.qbittorrent.org"))); } -void MainWindow::on_actionDocumentation_triggered() const { - QDesktopServices::openUrl(QUrl(QString::fromUtf8("http://doc.qbittorrent.org"))); +void MainWindow::on_actionDocumentation_triggered() const +{ + QDesktopServices::openUrl(QUrl(QString::fromUtf8("http://doc.qbittorrent.org"))); } -void MainWindow::on_actionBugReport_triggered() const { - QDesktopServices::openUrl(QUrl(QString::fromUtf8("http://bugs.qbittorrent.org"))); +void MainWindow::on_actionBugReport_triggered() const +{ + QDesktopServices::openUrl(QUrl(QString::fromUtf8("http://bugs.qbittorrent.org"))); } -void MainWindow::tab_changed(int new_tab) { - Q_UNUSED(new_tab); - // We cannot rely on the index new_tab - // because the tab order is undetermined now - if (tabs->currentWidget() == vSplitter) { - qDebug("Changed tab to transfer list, refreshing the list"); - properties->loadDynamicData(); - searchFilterAct->setVisible(true); - return; - } - else - searchFilterAct->setVisible(false); - if (tabs->currentWidget() == searchEngine) { - qDebug("Changed tab to search engine, giving focus to search input"); - searchEngine->giveFocusToSearchInput(); - } +void MainWindow::tab_changed(int new_tab) +{ + Q_UNUSED(new_tab); + // We cannot rely on the index new_tab + // because the tab order is undetermined now + if (tabs->currentWidget() == vSplitter) { + qDebug("Changed tab to transfer list, refreshing the list"); + properties->loadDynamicData(); + searchFilterAct->setVisible(true); + return; + } + else { + searchFilterAct->setVisible(false); + } + if (tabs->currentWidget() == searchEngine) { + qDebug("Changed tab to search engine, giving focus to search input"); + searchEngine->giveFocusToSearchInput(); + } } -void MainWindow::writeSettings() { - Preferences* const pref = Preferences::instance(); - pref->setMainGeometry(saveGeometry()); - // Splitter size - pref->setMainVSplitterState(vSplitter->saveState()); - properties->saveSettings(); +void MainWindow::writeSettings() +{ + Preferences* const pref = Preferences::instance(); + pref->setMainGeometry(saveGeometry()); + // Splitter size + pref->setMainVSplitterState(vSplitter->saveState()); + properties->saveSettings(); } -void MainWindow::readSettings() { - const Preferences* const pref = Preferences::instance(); - const QByteArray mainGeo = pref->getMainGeometry(); - if (!mainGeo.isEmpty()) { - if (restoreGeometry(mainGeo)) - m_posInitialized = true; - } - const QByteArray splitterState = pref->getMainVSplitterState(); - if (splitterState.isEmpty()) { - // Default sizes - vSplitter->setSizes(QList() << 120 << vSplitter->width()-120); - } else { - vSplitter->restoreState(splitterState); - } +void MainWindow::readSettings() +{ + const Preferences* const pref = Preferences::instance(); + const QByteArray mainGeo = pref->getMainGeometry(); + if (!mainGeo.isEmpty()) + if (restoreGeometry(mainGeo)) + m_posInitialized = true; + const QByteArray splitterState = pref->getMainVSplitterState(); + if (splitterState.isEmpty()) + // Default sizes + vSplitter->setSizes(QList() << 120 << vSplitter->width() - 120); + else + vSplitter->restoreState(splitterState); } -void MainWindow::balloonClicked() { - if (isHidden()) { - if (ui_locked) { - // Ask for UI lock password - if (!unlockUI()) - return; +void MainWindow::balloonClicked() +{ + if (isHidden()) { + if (ui_locked) { + // Ask for UI lock password + if (!unlockUI()) + return; + } + show(); + if (isMinimized()) + showNormal(); } - show(); - if (isMinimized()) - showNormal(); - } - raise(); - activateWindow(); + raise(); + activateWindow(); } // called when a torrent has finished -void MainWindow::finishedTorrent(const QTorrentHandle& h) const { - if (TorrentPersistentData::isSeed(h.hash())) - showNotificationBaloon(tr("Download completion"), tr("%1 has finished downloading.", "e.g: xxx.avi has finished downloading.").arg(h.name())); +void MainWindow::finishedTorrent(const QTorrentHandle& h) const +{ + if (TorrentPersistentData::isSeed(h.hash())) + showNotificationBaloon(tr("Download completion"), tr("%1 has finished downloading.", "e.g: xxx.avi has finished downloading.").arg(h.name())); } // Notification when disk is full -void MainWindow::fullDiskError(const QTorrentHandle& h, QString msg) const { - if (!h.is_valid()) return; - showNotificationBaloon(tr("I/O Error", "i.e: Input/Output Error"), tr("An I/O error occurred for torrent %1.\n Reason: %2", "e.g: An error occurred for torrent xxx.avi.\n Reason: disk is full.").arg(h.name()).arg(msg)); -} - -void MainWindow::createKeyboardShortcuts() { - actionCreate_torrent->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+N"))); - actionOpen->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+O"))); - actionDownload_from_URL->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift+O"))); - actionExit->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Q"))); - switchTransferShortcut = new QShortcut(QKeySequence("Alt+1"), this); - connect(switchTransferShortcut, SIGNAL(activated()), this, SLOT(displayTransferTab())); - switchSearchShortcut = new QShortcut(QKeySequence("Alt+2"), this); - connect(switchSearchShortcut, SIGNAL(activated()), this, SLOT(displaySearchTab())); - switchSearchShortcut2 = new QShortcut(QKeySequence("Ctrl+F"), this); - connect(switchSearchShortcut2, SIGNAL(activated()), this, SLOT(displaySearchTab())); - switchRSSShortcut = new QShortcut(QKeySequence("Alt+3"), this); - connect(switchRSSShortcut, SIGNAL(activated()), this, SLOT(displayRSSTab())); - actionDocumentation->setShortcut(QKeySequence("F1")); - actionOptions->setShortcut(QKeySequence(QString::fromUtf8("Alt+O"))); - actionStart->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+S"))); - actionStart_All->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift+S"))); - actionPause->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+P"))); - actionPause_All->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift+P"))); - actionBottomPriority->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift+-"))); - actionDecreasePriority->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+-"))); - actionIncreasePriority->setShortcut(QKeySequence(QString::fromUtf8("Ctrl++"))); - actionTopPriority->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift++"))); +void MainWindow::fullDiskError(const QTorrentHandle& h, QString msg) const +{ + if (!h.is_valid()) return; + showNotificationBaloon(tr("I/O Error", "i.e: Input/Output Error"), tr("An I/O error occurred for torrent %1.\n Reason: %2", "e.g: An error occurred for torrent xxx.avi.\n Reason: disk is full.").arg(h.name()).arg(msg)); +} + +void MainWindow::createKeyboardShortcuts() +{ + actionCreate_torrent->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+N"))); + actionOpen->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+O"))); + actionDownload_from_URL->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift+O"))); + actionExit->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Q"))); + switchTransferShortcut = new QShortcut(QKeySequence("Alt+1"), this); + connect(switchTransferShortcut, SIGNAL(activated()), this, SLOT(displayTransferTab())); + switchSearchShortcut = new QShortcut(QKeySequence("Alt+2"), this); + connect(switchSearchShortcut, SIGNAL(activated()), this, SLOT(displaySearchTab())); + switchSearchShortcut2 = new QShortcut(QKeySequence("Ctrl+F"), this); + connect(switchSearchShortcut2, SIGNAL(activated()), this, SLOT(displaySearchTab())); + switchRSSShortcut = new QShortcut(QKeySequence("Alt+3"), this); + connect(switchRSSShortcut, SIGNAL(activated()), this, SLOT(displayRSSTab())); + actionDocumentation->setShortcut(QKeySequence("F1")); + actionOptions->setShortcut(QKeySequence(QString::fromUtf8("Alt+O"))); + actionStart->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+S"))); + actionStart_All->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift+S"))); + actionPause->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+P"))); + actionPause_All->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift+P"))); + actionBottomPriority->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift+-"))); + actionDecreasePriority->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+-"))); + actionIncreasePriority->setShortcut(QKeySequence(QString::fromUtf8("Ctrl++"))); + actionTopPriority->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+Shift++"))); #ifdef Q_OS_MAC - actionMinimize->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+M"))); - addAction(actionMinimize); + actionMinimize->setShortcut(QKeySequence(QString::fromUtf8("Ctrl+M"))); + addAction(actionMinimize); #endif } // Keyboard shortcuts slots -void MainWindow::displayTransferTab() const { - tabs->setCurrentWidget(transferList); +void MainWindow::displayTransferTab() const +{ + tabs->setCurrentWidget(transferList); } -void MainWindow::displaySearchTab() const { - if (searchEngine) - tabs->setCurrentWidget(searchEngine); +void MainWindow::displaySearchTab() const +{ + if (searchEngine) + tabs->setCurrentWidget(searchEngine); } -void MainWindow::displayRSSTab() const { - if (rssWidget) - tabs->setCurrentWidget(rssWidget); +void MainWindow::displayRSSTab() const +{ + if (rssWidget) + tabs->setCurrentWidget(rssWidget); } // End of keyboard shortcuts slots -void MainWindow::askRecursiveTorrentDownloadConfirmation(const QTorrentHandle &h) { - Preferences* const pref = Preferences::instance(); - if (pref->recursiveDownloadDisabled()) return; - // Get Torrent name - QString torrent_name; - try { - torrent_name = h.name(); - } catch(invalid_handle&) { - return; - } - QMessageBox confirmBox(QMessageBox::Question, tr("Recursive download confirmation"), tr("The torrent %1 contains torrent files, do you want to proceed with their download?").arg(torrent_name)); - QPushButton *yes = confirmBox.addButton(tr("Yes"), QMessageBox::YesRole); - /*QPushButton *no = */confirmBox.addButton(tr("No"), QMessageBox::NoRole); - QPushButton *never = confirmBox.addButton(tr("Never"), QMessageBox::NoRole); - confirmBox.exec(); - if (confirmBox.clickedButton() == 0) return; - if (confirmBox.clickedButton() == yes) { - QBtSession::instance()->recursiveTorrentDownload(h); - return; - } - if (confirmBox.clickedButton() == never) { - pref->disableRecursiveDownload(); - } -} - -void MainWindow::handleDownloadFromUrlFailure(QString url, QString reason) const { - // Display a message box - showNotificationBaloon(tr("Url download error"), tr("Couldn't download file at url: %1, reason: %2.").arg(url).arg(reason)); -} - -void MainWindow::on_actionSet_global_upload_limit_triggered() { - qDebug("actionSet_global_upload_limit_triggered"); - bool ok; - int cur_limit = QBtSession::instance()->getSession()->settings().upload_rate_limit; - const long new_limit = SpeedLimitDialog::askSpeedLimit(&ok, tr("Global Upload Speed Limit"), cur_limit); - if (ok) { - qDebug("Setting global upload rate limit to %.1fKb/s", new_limit/1024.); - QBtSession::instance()->setUploadRateLimit(new_limit); - if (new_limit <= 0) - Preferences::instance()->setGlobalUploadLimit(-1); - else - Preferences::instance()->setGlobalUploadLimit(new_limit/1024.); - } -} - -void MainWindow::on_actionSet_global_download_limit_triggered() { - qDebug("actionSet_global_download_limit_triggered"); - bool ok; - int cur_limit = QBtSession::instance()->getSession()->settings().download_rate_limit; - const long new_limit = SpeedLimitDialog::askSpeedLimit(&ok, tr("Global Download Speed Limit"), cur_limit); - if (ok) { - qDebug("Setting global download rate limit to %.1fKb/s", new_limit/1024.); - QBtSession::instance()->setDownloadRateLimit(new_limit); - if (new_limit <= 0) - Preferences::instance()->setGlobalDownloadLimit(-1); - else - Preferences::instance()->setGlobalDownloadLimit(new_limit/1024.); - } +void MainWindow::askRecursiveTorrentDownloadConfirmation(const QTorrentHandle &h) +{ + Preferences* const pref = Preferences::instance(); + if (pref->recursiveDownloadDisabled()) return; + // Get Torrent name + QString torrent_name; + try { + torrent_name = h.name(); + } catch(invalid_handle&) { + return; + } + QMessageBox confirmBox(QMessageBox::Question, tr("Recursive download confirmation"), tr("The torrent %1 contains torrent files, do you want to proceed with their download?").arg(torrent_name)); + QPushButton *yes = confirmBox.addButton(tr("Yes"), QMessageBox::YesRole); + /*QPushButton *no = */ confirmBox.addButton(tr("No"), QMessageBox::NoRole); + QPushButton *never = confirmBox.addButton(tr("Never"), QMessageBox::NoRole); + confirmBox.exec(); + if (confirmBox.clickedButton() == 0) return; + if (confirmBox.clickedButton() == yes) { + QBtSession::instance()->recursiveTorrentDownload(h); + return; + } + if (confirmBox.clickedButton() == never) + pref->disableRecursiveDownload(); +} + +void MainWindow::handleDownloadFromUrlFailure(QString url, QString reason) const +{ + // Display a message box + showNotificationBaloon(tr("Url download error"), tr("Couldn't download file at url: %1, reason: %2.").arg(url).arg(reason)); +} + +void MainWindow::on_actionSet_global_upload_limit_triggered() +{ + qDebug("actionSet_global_upload_limit_triggered"); + bool ok; + int cur_limit = QBtSession::instance()->getSession()->settings().upload_rate_limit; + const long new_limit = SpeedLimitDialog::askSpeedLimit(&ok, tr("Global Upload Speed Limit"), cur_limit); + if (ok) { + qDebug("Setting global upload rate limit to %.1fKb/s", new_limit / 1024.); + QBtSession::instance()->setUploadRateLimit(new_limit); + if (new_limit <= 0) + Preferences::instance()->setGlobalUploadLimit(-1); + else + Preferences::instance()->setGlobalUploadLimit(new_limit / 1024.); + } +} + +void MainWindow::on_actionSet_global_download_limit_triggered() +{ + qDebug("actionSet_global_download_limit_triggered"); + bool ok; + int cur_limit = QBtSession::instance()->getSession()->settings().download_rate_limit; + const long new_limit = SpeedLimitDialog::askSpeedLimit(&ok, tr("Global Download Speed Limit"), cur_limit); + if (ok) { + qDebug("Setting global download rate limit to %.1fKb/s", new_limit / 1024.); + QBtSession::instance()->setDownloadRateLimit(new_limit); + if (new_limit <= 0) + Preferences::instance()->setGlobalDownloadLimit(-1); + else + Preferences::instance()->setGlobalDownloadLimit(new_limit / 1024.); + } } // Necessary if we want to close the window // in one time if "close to systray" is enabled -void MainWindow::on_actionExit_triggered() { - // UI locking enforcement. - if (isHidden() && ui_locked) { - // Ask for UI lock password - if (!unlockUI()) - return; - } +void MainWindow::on_actionExit_triggered() +{ + // UI locking enforcement. + if (isHidden() && ui_locked) { + // Ask for UI lock password + if (!unlockUI()) + return; + } - force_exit = true; - close(); + force_exit = true; + close(); } -QWidget* MainWindow::getCurrentTabWidget() const { - if (isMinimized() || !isVisible()) - return 0; - if (tabs->currentIndex() == 0) - return transferList; - return tabs->currentWidget(); +QWidget* MainWindow::getCurrentTabWidget() const +{ + if (isMinimized() || !isVisible()) + return 0; + if (tabs->currentIndex() == 0) + return transferList; + return tabs->currentWidget(); } -void MainWindow::setTabText(int index, QString text) const { - tabs->setTabText(index, text); +void MainWindow::setTabText(int index, QString text) const +{ + tabs->setTabText(index, text); } -bool MainWindow::unlockUI() { - if (unlockDlgShowing) +bool MainWindow::unlockUI() +{ + if (unlockDlgShowing) + return false; + else + unlockDlgShowing = true; + + bool ok = false; + QString clear_password = AutoExpandableDialog::getText(this, tr("UI lock password"), tr("Please type the UI lock password:"), QLineEdit::Password, "", &ok); + unlockDlgShowing = false; + if (!ok) return false; + Preferences* const pref = Preferences::instance(); + QString real_pass_md5 = pref->getUILockPasswordMD5(); + QCryptographicHash md5(QCryptographicHash::Md5); + md5.addData(clear_password.toLocal8Bit()); + QString password_md5 = md5.result().toHex(); + if (real_pass_md5 == password_md5) { + ui_locked = false; + pref->setUILocked(false); + myTrayIconMenu->setEnabled(true); + return true; + } + QMessageBox::warning(this, tr("Invalid password"), tr("The password is invalid")); return false; - else - unlockDlgShowing = true; - - bool ok = false; - QString clear_password = AutoExpandableDialog::getText(this, tr("UI lock password"), tr("Please type the UI lock password:"), QLineEdit::Password, "", &ok); - unlockDlgShowing = false; - if (!ok) return false; - Preferences* const pref = Preferences::instance(); - QString real_pass_md5 = pref->getUILockPasswordMD5(); - QCryptographicHash md5(QCryptographicHash::Md5); - md5.addData(clear_password.toLocal8Bit()); - QString password_md5 = md5.result().toHex(); - if (real_pass_md5 == password_md5) { - ui_locked = false; - pref->setUILocked(false); - myTrayIconMenu->setEnabled(true); - return true; - } - QMessageBox::warning(this, tr("Invalid password"), tr("The password is invalid")); - return false; -} - -void MainWindow::notifyOfUpdate(QString) { - // Show restart message - status_bar->showRestartRequired(); - // Delete the executable watcher - delete executable_watcher; - executable_watcher = 0; +} + +void MainWindow::notifyOfUpdate(QString) +{ + // Show restart message + status_bar->showRestartRequired(); + // Delete the executable watcher + delete executable_watcher; + executable_watcher = 0; } // Toggle Main window visibility -void MainWindow::toggleVisibility(QSystemTrayIcon::ActivationReason e) { - if (e == QSystemTrayIcon::Trigger || e == QSystemTrayIcon::DoubleClick) { - if (isHidden()) { - if (ui_locked) { - // Ask for UI lock password - if (!unlockUI()) - return; - } - // Make sure the window is not minimized - setWindowState(windowState() & (~Qt::WindowMinimized | Qt::WindowActive)); - // Then show it - show(); - raise(); - activateWindow(); - }else{ - hide(); +void MainWindow::toggleVisibility(QSystemTrayIcon::ActivationReason e) +{ + if (e == QSystemTrayIcon::Trigger || e == QSystemTrayIcon::DoubleClick) { + if (isHidden()) { + if (ui_locked) { + // Ask for UI lock password + if (!unlockUI()) + return; + } + // Make sure the window is not minimized + setWindowState(windowState() & (~Qt::WindowMinimized | Qt::WindowActive)); + // Then show it + show(); + raise(); + activateWindow(); + } + else { + hide(); + } } - } } // Display About Dialog -void MainWindow::on_actionAbout_triggered() { - //About dialog - if (aboutDlg) { - aboutDlg->setFocus(); - } else { - aboutDlg = new about(this); - } +void MainWindow::on_actionAbout_triggered() +{ + //About dialog + if (aboutDlg) + aboutDlg->setFocus(); + else + aboutDlg = new about(this); } -void MainWindow::on_actionStatistics_triggered() { - if (statsDlg) - statsDlg->setFocus(); - else - statsDlg = new StatsDialog(this); +void MainWindow::on_actionStatistics_triggered() +{ + if (statsDlg) + statsDlg->setFocus(); + else + statsDlg = new StatsDialog(this); } -void MainWindow::showEvent(QShowEvent *e) { - qDebug("** Show Event **"); +void MainWindow::showEvent(QShowEvent *e) +{ + qDebug("** Show Event **"); - if (getCurrentTabWidget() == transferList) { - properties->loadDynamicData(); - } + if (getCurrentTabWidget() == transferList) + properties->loadDynamicData(); - e->accept(); + e->accept(); - // Make sure the window is initially centered - if (!m_posInitialized) { - move(misc::screenCenter(this)); - m_posInitialized = true; - } + // Make sure the window is initially centered + if (!m_posInitialized) { + move(misc::screenCenter(this)); + m_posInitialized = true; + } } // Called when we close the program -void MainWindow::closeEvent(QCloseEvent *e) { - Preferences* const pref = Preferences::instance(); - const bool goToSystrayOnExit = pref->closeToTray(); - if (!force_exit && systrayIcon && goToSystrayOnExit && !this->isHidden()) { - hide(); - e->accept(); - return; - } - if (pref->confirmOnExit() && QBtSession::instance()->hasActiveTorrents()) { - if (e->spontaneous() || force_exit) { - if (!isVisible()) - show(); - QMessageBox confirmBox(QMessageBox::Question, tr("Exiting qBittorrent"), - tr("Some files are currently transferring.\nAre you sure you want to quit qBittorrent?"), - QMessageBox::NoButton, this); - QPushButton *noBtn = confirmBox.addButton(tr("No"), QMessageBox::NoRole); - QPushButton *yesBtn = confirmBox.addButton(tr("Yes"), QMessageBox::YesRole); - QPushButton *alwaysBtn = confirmBox.addButton(tr("Always"), QMessageBox::YesRole); - confirmBox.setDefaultButton(yesBtn); - confirmBox.exec(); - if (!confirmBox.clickedButton() || confirmBox.clickedButton() == noBtn) { - // Cancel exit - e->ignore(); - force_exit = false; +void MainWindow::closeEvent(QCloseEvent *e) +{ + Preferences* const pref = Preferences::instance(); + const bool goToSystrayOnExit = pref->closeToTray(); + if (!force_exit && systrayIcon && goToSystrayOnExit && !this->isHidden()) { + hide(); + e->accept(); return; - } - if (confirmBox.clickedButton() == alwaysBtn) { - // Remember choice - Preferences::instance()->setConfirmOnExit(false); - } } - } - hide(); - if (systrayIcon) { - // Hide tray icon - systrayIcon->hide(); - } - // Save window size, columns size - writeSettings(); - // Accept exit - e->accept(); - qApp->exit(); + if (pref->confirmOnExit() && QBtSession::instance()->hasActiveTorrents()) { + if (e->spontaneous() || force_exit) { + if (!isVisible()) + show(); + QMessageBox confirmBox(QMessageBox::Question, tr("Exiting qBittorrent"), + tr("Some files are currently transferring.\nAre you sure you want to quit qBittorrent?"), + QMessageBox::NoButton, this); + QPushButton *noBtn = confirmBox.addButton(tr("No"), QMessageBox::NoRole); + QPushButton *yesBtn = confirmBox.addButton(tr("Yes"), QMessageBox::YesRole); + QPushButton *alwaysBtn = confirmBox.addButton(tr("Always"), QMessageBox::YesRole); + confirmBox.setDefaultButton(yesBtn); + confirmBox.exec(); + if (!confirmBox.clickedButton() || confirmBox.clickedButton() == noBtn) { + // Cancel exit + e->ignore(); + force_exit = false; + return; + } + if (confirmBox.clickedButton() == alwaysBtn) + // Remember choice + Preferences::instance()->setConfirmOnExit(false); + } + } + hide(); + if (systrayIcon) + // Hide tray icon + systrayIcon->hide(); + // Save window size, columns size + writeSettings(); + // Accept exit + e->accept(); + qApp->exit(); } // Display window to create a torrent -void MainWindow::on_actionCreate_torrent_triggered() { - if (createTorrentDlg) { - createTorrentDlg->setFocus(); - } else { - createTorrentDlg = new TorrentCreatorDlg(this); - connect(createTorrentDlg, SIGNAL(torrent_to_seed(QString)), this, SLOT(addTorrent(QString))); - } -} - -bool MainWindow::event(QEvent * e) { - switch(e->type()) { - case QEvent::WindowStateChange: { - qDebug("Window change event"); - //Now check to see if the window is minimised - if (isMinimized()) { - qDebug("minimisation"); - if (systrayIcon && Preferences::instance()->minimizeToTray()) { - qDebug("Has active window: %d", (int)(qApp->activeWindow() != 0)); - // Check if there is a modal window - bool has_modal_window = false; - foreach (QWidget *widget, QApplication::allWidgets()) { - if (widget->isModal()) { - has_modal_window = true; - break; - } - } - // Iconify if there is no modal window - if (!has_modal_window) { - qDebug("Minimize to Tray enabled, hiding!"); - e->ignore(); - QTimer::singleShot(0, this, SLOT(hide())); - return true; +void MainWindow::on_actionCreate_torrent_triggered() +{ + if (createTorrentDlg) { + createTorrentDlg->setFocus(); + } + else { + createTorrentDlg = new TorrentCreatorDlg(this); + connect(createTorrentDlg, SIGNAL(torrent_to_seed(QString)), this, SLOT(addTorrent(QString))); + } +} + +bool MainWindow::event(QEvent * e) +{ + switch(e->type()) { + case QEvent::WindowStateChange: { + qDebug("Window change event"); + //Now check to see if the window is minimised + if (isMinimized()) { + qDebug("minimisation"); + if (systrayIcon && Preferences::instance()->minimizeToTray()) { + qDebug("Has active window: %d", (int)(qApp->activeWindow() != 0)); + // Check if there is a modal window + bool has_modal_window = false; + foreach (QWidget *widget, QApplication::allWidgets()) { + if (widget->isModal()) { + has_modal_window = true; + break; + } + } + // Iconify if there is no modal window + if (!has_modal_window) { + qDebug("Minimize to Tray enabled, hiding!"); + e->ignore(); + QTimer::singleShot(0, this, SLOT(hide())); + return true; + } + } } - } + break; } - break; - } #ifdef Q_OS_MAC - case QEvent::ToolBarChange: { - qDebug("MAC: Received a toolbar change event!"); - bool ret = QMainWindow::event(e); - - qDebug("MAC: new toolbar visibility is %d", !actionTop_tool_bar->isChecked()); - actionTop_tool_bar->toggle(); - Preferences::instance()->setToolbarDisplayed(actionTop_tool_bar->isChecked()); - return ret; - } + case QEvent::ToolBarChange: { + qDebug("MAC: Received a toolbar change event!"); + bool ret = QMainWindow::event(e); + + qDebug("MAC: new toolbar visibility is %d", !actionTop_tool_bar->isChecked()); + actionTop_tool_bar->toggle(); + Preferences::instance()->setToolbarDisplayed(actionTop_tool_bar->isChecked()); + return ret; + } #endif - default: - break; - } - return QMainWindow::event(e); + default: + break; + } + return QMainWindow::event(e); } // Action executed when a file is dropped -void MainWindow::dropEvent(QDropEvent *event) { - event->acceptProposedAction(); - QStringList files; - if (event->mimeData()->hasUrls()) { - const QList urls = event->mimeData()->urls(); - foreach (const QUrl &url, urls) { - if (!url.isEmpty()) { - if (url.scheme().compare("file", Qt::CaseInsensitive) == 0) - files << url.toLocalFile(); - else - files << url.toString(); - } - } - } else { - files = event->mimeData()->text().split(QString::fromUtf8("\n")); - } - // Add file to download list - Preferences* const pref = Preferences::instance(); - const bool useTorrentAdditionDialog = pref->useAdditionDialog(); - foreach (QString file, files) { - qDebug("Dropped file %s on download list", qPrintable(file)); - if (misc::isUrl(file)) { - QBtSession::instance()->downloadFromUrl(file); - continue; +void MainWindow::dropEvent(QDropEvent *event) +{ + event->acceptProposedAction(); + QStringList files; + if (event->mimeData()->hasUrls()) { + const QList urls = event->mimeData()->urls(); + foreach (const QUrl &url, urls) { + if (!url.isEmpty()) { + if (url.scheme().compare("file", Qt::CaseInsensitive) == 0) + files << url.toLocalFile(); + else + files << url.toString(); + } + } } - // Bitcomet or Magnet link - if (file.startsWith("bc://bt/", Qt::CaseInsensitive)) { - qDebug("Converting bc link to magnet link"); - file = misc::bcLinkToMagnet(file); + else { + files = event->mimeData()->text().split(QString::fromUtf8("\n")); } - if (file.startsWith("magnet:", Qt::CaseInsensitive)) { - if (useTorrentAdditionDialog) - AddNewTorrentDialog::showMagnet(file, this); - else - QBtSession::instance()->addMagnetUri(file); - } else { - // Local file - if (useTorrentAdditionDialog) - AddNewTorrentDialog::showTorrent(file, QString(), this); - else - QBtSession::instance()->addTorrent(file); + // Add file to download list + Preferences* const pref = Preferences::instance(); + const bool useTorrentAdditionDialog = pref->useAdditionDialog(); + foreach (QString file, files) { + qDebug("Dropped file %s on download list", qPrintable(file)); + if (misc::isUrl(file)) { + QBtSession::instance()->downloadFromUrl(file); + continue; + } + // Bitcomet or Magnet link + if (file.startsWith("bc://bt/", Qt::CaseInsensitive)) { + qDebug("Converting bc link to magnet link"); + file = misc::bcLinkToMagnet(file); + } + if (file.startsWith("magnet:", Qt::CaseInsensitive)) { + if (useTorrentAdditionDialog) + AddNewTorrentDialog::showMagnet(file, this); + else + QBtSession::instance()->addMagnetUri(file); + } + else { + // Local file + if (useTorrentAdditionDialog) + AddNewTorrentDialog::showTorrent(file, QString(), this); + else + QBtSession::instance()->addTorrent(file); + } } - } } // Decode if we accept drag 'n drop or not -void MainWindow::dragEnterEvent(QDragEnterEvent *event) { - foreach (const QString &mime, event->mimeData()->formats()) { - qDebug("mimeData: %s", mime.toLocal8Bit().data()); - } - if (event->mimeData()->hasFormat(QString::fromUtf8("text/plain")) || event->mimeData()->hasFormat(QString::fromUtf8("text/uri-list"))) { - event->acceptProposedAction(); - } +void MainWindow::dragEnterEvent(QDragEnterEvent *event) +{ + foreach (const QString &mime, event->mimeData()->formats()) + qDebug("mimeData: %s", mime.toLocal8Bit().data()); + if (event->mimeData()->hasFormat(QString::fromUtf8("text/plain")) || event->mimeData()->hasFormat(QString::fromUtf8("text/uri-list"))) + event->acceptProposedAction(); } /***************************************************** - * * - * Torrent * - * * - *****************************************************/ +* * +* Torrent * +* * +*****************************************************/ // Display a dialog to allow user to add // torrents to download list -void MainWindow::on_actionOpen_triggered() { - Preferences* const pref = Preferences::instance(); - // Open File Open Dialog - // Note: it is possible to select more than one file - const QStringList pathsList = QFileDialog::getOpenFileNames(0, - tr("Open Torrent Files"), pref->getMainLastDir(), - tr("Torrent Files")+QString::fromUtf8(" (*.torrent)")); - if (!pathsList.empty()) { - const uint listSize = pathsList.size(); - for (uint i=0; iuseAdditionDialog()) - AddNewTorrentDialog::showTorrent(pathsList.at(i), QString(), this); - else - QBtSession::instance()->addTorrent(pathsList.at(i)); +void MainWindow::on_actionOpen_triggered() +{ + Preferences* const pref = Preferences::instance(); + // Open File Open Dialog + // Note: it is possible to select more than one file + const QStringList pathsList = QFileDialog::getOpenFileNames(0, + tr("Open Torrent Files"), pref->getMainLastDir(), + tr("Torrent Files") + QString::fromUtf8(" (*.torrent)")); + if (!pathsList.empty()) { + const uint listSize = pathsList.size(); + for (uint i = 0; iuseAdditionDialog()) + AddNewTorrentDialog::showTorrent(pathsList.at(i), QString(), this); + else + QBtSession::instance()->addTorrent(pathsList.at(i)); + } + // Save last dir to remember it + QStringList top_dir = fsutils::fromNativePath(pathsList.at(0)).split("/"); + top_dir.removeLast(); + pref->setMainLastDir(fsutils::fromNativePath(top_dir.join("/"))); } - // Save last dir to remember it - QStringList top_dir = fsutils::fromNativePath(pathsList.at(0)).split("/"); - top_dir.removeLast(); - pref->setMainLastDir(fsutils::fromNativePath(top_dir.join("/"))); - } } // As program parameters, we can get paths or urls. // This function parse the parameters and call // the right addTorrent function, considering // the parameter type. -void MainWindow::processParams(const QString& params_str) { - processParams(params_str.split("|", QString::SkipEmptyParts)); -} - -void MainWindow::processParams(const QStringList& params) { - Preferences* const pref = Preferences::instance(); - const bool useTorrentAdditionDialog = pref->useAdditionDialog(); - foreach (QString param, params) { - param = param.trimmed(); - if (misc::isUrl(param)) { - QBtSession::instance()->downloadFromUrl(param); - }else{ - if(param.startsWith("qbt://show")) { - if(ui_locked) { - if(!unlockUI()) - return; +void MainWindow::processParams(const QString& params_str) +{ + processParams(params_str.split("|", QString::SkipEmptyParts)); +} + +void MainWindow::processParams(const QStringList& params) +{ + Preferences* const pref = Preferences::instance(); + const bool useTorrentAdditionDialog = pref->useAdditionDialog(); + foreach (QString param, params) { + param = param.trimmed(); + if (misc::isUrl(param)) { + QBtSession::instance()->downloadFromUrl(param); + } + else { + if(param.startsWith("qbt://show")) { + if(ui_locked) + if(!unlockUI()) + return; + show(); + activateWindow(); + raise(); + return; // Do not process more params + } + if (param.startsWith("bc://bt/", Qt::CaseInsensitive)) { + qDebug("Converting bc link to magnet link"); + param = misc::bcLinkToMagnet(param); + } + if (param.startsWith("magnet:", Qt::CaseInsensitive)) { + if (useTorrentAdditionDialog) + AddNewTorrentDialog::showMagnet(param, this); + else + QBtSession::instance()->addMagnetUri(param); + } + else { + if (useTorrentAdditionDialog) + AddNewTorrentDialog::showTorrent(param, QString(), this); + else + QBtSession::instance()->addTorrent(param); + } } - show(); - activateWindow(); - raise(); - return; // Do not process more params - } - if (param.startsWith("bc://bt/", Qt::CaseInsensitive)) { - qDebug("Converting bc link to magnet link"); - param = misc::bcLinkToMagnet(param); - } - if (param.startsWith("magnet:", Qt::CaseInsensitive)) { - if (useTorrentAdditionDialog) - AddNewTorrentDialog::showMagnet(param, this); - else - QBtSession::instance()->addMagnetUri(param); - } else { - if (useTorrentAdditionDialog) - AddNewTorrentDialog::showTorrent(param, QString(), this); - else - QBtSession::instance()->addTorrent(param); - } } - } } -void MainWindow::addTorrent(QString path) { - QBtSession::instance()->addTorrent(path); +void MainWindow::addTorrent(QString path) +{ + QBtSession::instance()->addTorrent(path); } -void MainWindow::processDownloadedFiles(QString path, QString url) { - Preferences* const pref = Preferences::instance(); - if (pref->useAdditionDialog()) - AddNewTorrentDialog::showTorrent(path, url, this); - else - QBtSession::instance()->addTorrent(path, false, url); +void MainWindow::processDownloadedFiles(QString path, QString url) +{ + Preferences* const pref = Preferences::instance(); + if (pref->useAdditionDialog()) + AddNewTorrentDialog::showTorrent(path, url, this); + else + QBtSession::instance()->addTorrent(path, false, url); } -void MainWindow::processNewMagnetLink(const QString& link) { - Preferences* const pref = Preferences::instance(); - if (pref->useAdditionDialog()) - AddNewTorrentDialog::showMagnet(link, this); - else - QBtSession::instance()->addMagnetUri(link); +void MainWindow::processNewMagnetLink(const QString& link) +{ + Preferences* const pref = Preferences::instance(); + if (pref->useAdditionDialog()) + AddNewTorrentDialog::showMagnet(link, this); + else + QBtSession::instance()->addMagnetUri(link); } -void MainWindow::optionsSaved() { - loadPreferences(); +void MainWindow::optionsSaved() +{ + loadPreferences(); } // Load program preferences -void MainWindow::loadPreferences(bool configure_session) { - QBtSession::instance()->addConsoleMessage(tr("Options were saved successfully.")); - const Preferences* const pref = Preferences::instance(); - const bool newSystrayIntegration = pref->systrayIntegration(); - actionLock_qBittorrent->setVisible(newSystrayIntegration); - if (newSystrayIntegration != (systrayIcon!=0)) { - if (newSystrayIntegration) { - // create the trayicon - if (!QSystemTrayIcon::isSystemTrayAvailable()) { - if (!configure_session) { // Program startup - systrayCreator = new QTimer(this); - connect(systrayCreator, SIGNAL(timeout()), this, SLOT(createSystrayDelayed())); - systrayCreator->setSingleShot(true); - systrayCreator->start(2000); - qDebug("Info: System tray is unavailable, trying again later."); - } else { - qDebug("Warning: System tray is unavailable."); +void MainWindow::loadPreferences(bool configure_session) +{ + QBtSession::instance()->addConsoleMessage(tr("Options were saved successfully.")); + const Preferences* const pref = Preferences::instance(); + const bool newSystrayIntegration = pref->systrayIntegration(); + actionLock_qBittorrent->setVisible(newSystrayIntegration); + if (newSystrayIntegration != (systrayIcon!=0)) { + if (newSystrayIntegration) { + // create the trayicon + if (!QSystemTrayIcon::isSystemTrayAvailable()) { + if (!configure_session) { // Program startup + systrayCreator = new QTimer(this); + connect(systrayCreator, SIGNAL(timeout()), this, SLOT(createSystrayDelayed())); + systrayCreator->setSingleShot(true); + systrayCreator->start(2000); + qDebug("Info: System tray is unavailable, trying again later."); + } + else { + qDebug("Warning: System tray is unavailable."); + } + } + else { + createTrayIcon(); + } + } + else { + // Destroy trayicon + delete systrayIcon; + delete myTrayIconMenu; } - } else { - createTrayIcon(); - } - } else { - // Destroy trayicon - delete systrayIcon; - delete myTrayIconMenu; } - } - // Reload systray icon - if (newSystrayIntegration && systrayIcon) { - systrayIcon->setIcon(getSystrayIcon()); - } - // General - if (pref->isToolbarDisplayed()) { - toolBar->setVisible(true); - } else { - // Clear search filter before hiding the top toolbar - search_filter->clear(); - toolBar->setVisible(false); - } - - if (pref->preventFromSuspend()) - { - preventTimer->start(PREVENT_SUSPEND_INTERVAL); - } - else - { - preventTimer->stop(); - m_pwr->setActivityState(false); - } - - const uint new_refreshInterval = pref->getRefreshInterval(); - transferList->setRefreshInterval(new_refreshInterval); - transferList->setAlternatingRowColors(pref->useAlternatingRowColors()); - properties->getFilesList()->setAlternatingRowColors(pref->useAlternatingRowColors()); - properties->getTrackerList()->setAlternatingRowColors(pref->useAlternatingRowColors()); - properties->getPeerList()->setAlternatingRowColors(pref->useAlternatingRowColors()); - - // Queueing System - if (pref->isQueueingSystemEnabled()) { - if (!actionDecreasePriority->isVisible()) { - transferList->hidePriorityColumn(false); - actionDecreasePriority->setVisible(true); - actionIncreasePriority->setVisible(true); - actionTopPriority->setVisible(true); - actionBottomPriority->setVisible(true); - prioSeparator->setVisible(true); - prioSeparatorMenu->setVisible(true); + // Reload systray icon + if (newSystrayIntegration && systrayIcon) + systrayIcon->setIcon(getSystrayIcon()); + // General + if (pref->isToolbarDisplayed()) { + toolBar->setVisible(true); + } + else { + // Clear search filter before hiding the top toolbar + search_filter->clear(); + toolBar->setVisible(false); + } + + if (pref->preventFromSuspend()) { + preventTimer->start(PREVENT_SUSPEND_INTERVAL); + } + else { + preventTimer->stop(); + m_pwr->setActivityState(false); + } + + const uint new_refreshInterval = pref->getRefreshInterval(); + transferList->setRefreshInterval(new_refreshInterval); + transferList->setAlternatingRowColors(pref->useAlternatingRowColors()); + properties->getFilesList()->setAlternatingRowColors(pref->useAlternatingRowColors()); + properties->getTrackerList()->setAlternatingRowColors(pref->useAlternatingRowColors()); + properties->getPeerList()->setAlternatingRowColors(pref->useAlternatingRowColors()); + + // Queueing System + if (pref->isQueueingSystemEnabled()) { + if (!actionDecreasePriority->isVisible()) { + transferList->hidePriorityColumn(false); + actionDecreasePriority->setVisible(true); + actionIncreasePriority->setVisible(true); + actionTopPriority->setVisible(true); + actionBottomPriority->setVisible(true); + prioSeparator->setVisible(true); + prioSeparatorMenu->setVisible(true); + } } - } else { - if (actionDecreasePriority->isVisible()) { - transferList->hidePriorityColumn(true); - actionDecreasePriority->setVisible(false); - actionIncreasePriority->setVisible(false); - actionTopPriority->setVisible(false); - actionBottomPriority->setVisible(false); - prioSeparator->setVisible(false); - prioSeparatorMenu->setVisible(false); + else { + if (actionDecreasePriority->isVisible()) { + transferList->hidePriorityColumn(true); + actionDecreasePriority->setVisible(false); + actionIncreasePriority->setVisible(false); + actionTopPriority->setVisible(false); + actionBottomPriority->setVisible(false); + prioSeparator->setVisible(false); + prioSeparatorMenu->setVisible(false); + } } - } - // Torrent properties - properties->reloadPreferences(); + // Torrent properties + properties->reloadPreferences(); - // Icon provider + // Icon provider #if (defined(Q_OS_UNIX) && !defined(Q_OS_MAC)) - IconProvider::instance()->useSystemIconTheme(pref->useSystemIconTheme()); + IconProvider::instance()->useSystemIconTheme(pref->useSystemIconTheme()); #endif - if (configure_session) - QBtSession::instance()->configureSession(); + if (configure_session) + QBtSession::instance()->configureSession(); #if defined(Q_OS_WIN) || defined(Q_OS_MAC) - if (pref->isUpdateCheckEnabled()) - checkProgramUpdate(); - else - programUpdateTimer.stop(); + if (pref->isUpdateCheckEnabled()) + checkProgramUpdate(); + else + programUpdateTimer.stop(); #endif - qDebug("GUI settings loaded"); + qDebug("GUI settings loaded"); } -void MainWindow::addUnauthenticatedTracker(const QPair &tracker) { - // Trackers whose authentication was cancelled - if (unauthenticated_trackers.indexOf(tracker) < 0) { - unauthenticated_trackers << tracker; - } +void MainWindow::addUnauthenticatedTracker(const QPair &tracker) +{ + // Trackers whose authentication was cancelled + if (unauthenticated_trackers.indexOf(tracker) < 0) + unauthenticated_trackers << tracker; } // Called when a tracker requires authentication -void MainWindow::trackerAuthenticationRequired(const QTorrentHandle& h) { - if (unauthenticated_trackers.indexOf(QPair(h, h.current_tracker())) < 0) { - // Tracker login - new trackerLogin(this, h); - } +void MainWindow::trackerAuthenticationRequired(const QTorrentHandle& h) +{ + if (unauthenticated_trackers.indexOf(QPair(h, h.current_tracker())) < 0) + // Tracker login + new trackerLogin(this, h); } // Check connection status and display right icon -void MainWindow::updateGUI() { - // update global informations - if (systrayIcon) { +void MainWindow::updateGUI() +{ + // update global informations + if (systrayIcon) { #if defined(Q_OS_UNIX) - QString html = "
"; - html += "qBittorrent"; - html += "
"; - html += "
"; - html += " "+tr("DL speed: %1 KiB/s", "e.g: Download speed: 10 KiB/s").arg(misc::accurateDoubleToString(QBtSession::instance()->getPayloadDownloadRate()/1024., 1)); - html += "
"; - html += "
"; - html += " "+tr("UP speed: %1 KiB/s", "e.g: Upload speed: 10 KiB/s").arg(misc::accurateDoubleToString(QBtSession::instance()->getPayloadUploadRate()/1024., 1)); - html += "
"; + QString html = "
"; + html += "qBittorrent"; + html += "
"; + html += "
"; + html += " " + tr("DL speed: %1 KiB/s", "e.g: Download speed: 10 KiB/s").arg(misc::accurateDoubleToString(QBtSession::instance()->getPayloadDownloadRate() / 1024., 1)); + html += "
"; + html += "
"; + html += " " + tr("UP speed: %1 KiB/s", "e.g: Upload speed: 10 KiB/s").arg(misc::accurateDoubleToString(QBtSession::instance()->getPayloadUploadRate() / 1024., 1)); + html += "
"; #else - // OSes such as Windows do not support html here - QString html =tr("DL speed: %1 KiB/s", "e.g: Download speed: 10 KiB/s").arg(misc::accurateDoubleToString(QBtSession::instance()->getPayloadDownloadRate()/1024., 1)); - html += "\n"; - html += tr("UP speed: %1 KiB/s", "e.g: Upload speed: 10 KiB/s").arg(misc::accurateDoubleToString(QBtSession::instance()->getPayloadUploadRate()/1024., 1)); + // OSes such as Windows do not support html here + QString html = tr("DL speed: %1 KiB/s", "e.g: Download speed: 10 KiB/s").arg(misc::accurateDoubleToString(QBtSession::instance()->getPayloadDownloadRate() / 1024., 1)); + html += "\n"; + html += tr("UP speed: %1 KiB/s", "e.g: Upload speed: 10 KiB/s").arg(misc::accurateDoubleToString(QBtSession::instance()->getPayloadUploadRate() / 1024., 1)); #endif - systrayIcon->setToolTip(html); // tray icon - } - if (displaySpeedInTitle) { - setWindowTitle(tr("[D: %1/s, U: %2/s] qBittorrent %3", "D = Download; U = Upload; %3 is qBittorrent version").arg(misc::friendlyUnit(QBtSession::instance()->getSessionStatus().payload_download_rate)).arg(misc::friendlyUnit(QBtSession::instance()->getSessionStatus().payload_upload_rate)).arg(QString::fromUtf8(VERSION))); - } + systrayIcon->setToolTip(html); // tray icon + } + if (displaySpeedInTitle) + setWindowTitle(tr("[D: %1/s, U: %2/s] qBittorrent %3", "D = Download; U = Upload; %3 is qBittorrent version").arg(misc::friendlyUnit(QBtSession::instance()->getSessionStatus().payload_download_rate)).arg(misc::friendlyUnit(QBtSession::instance()->getSessionStatus().payload_upload_rate)).arg(QString::fromUtf8(VERSION))); } -void MainWindow::showNotificationBaloon(QString title, QString msg) const { - if (!Preferences::instance()->useProgramNotification()) return; +void MainWindow::showNotificationBaloon(QString title, QString msg) const +{ + if (!Preferences::instance()->useProgramNotification()) return; #if (defined(Q_OS_UNIX) && !defined(Q_OS_MAC)) && defined(QT_DBUS_LIB) - org::freedesktop::Notifications notifications("org.freedesktop.Notifications", - "/org/freedesktop/Notifications", - QDBusConnection::sessionBus()); - // Testing for 'notifications.isValid()' isn't helpful here. - // If the notification daemon is configured to run 'as needed' - // the above check can be false if the daemon wasn't started - // by another application. In this case DBus will be able to - // start the notification daemon and complete our request. Such - // a daemon is xfce4-notifyd, DBus autostarts it and after - // some inactivity shuts it down. Other DEs, like GNOME, choose - // to start their daemons at the session startup and have it sit - // idling for the whole session. - QVariantMap hints; - hints["desktop-entry"] = "qBittorrent"; - QDBusPendingReply reply = notifications.Notify("qBittorrent", 0, "qbittorrent", title, - msg, QStringList(), hints, -1); - reply.waitForFinished(); - if (!reply.isError()) - return; + org::freedesktop::Notifications notifications("org.freedesktop.Notifications", + "/org/freedesktop/Notifications", + QDBusConnection::sessionBus()); + // Testing for 'notifications.isValid()' isn't helpful here. + // If the notification daemon is configured to run 'as needed' + // the above check can be false if the daemon wasn't started + // by another application. In this case DBus will be able to + // start the notification daemon and complete our request. Such + // a daemon is xfce4-notifyd, DBus autostarts it and after + // some inactivity shuts it down. Other DEs, like GNOME, choose + // to start their daemons at the session startup and have it sit + // idling for the whole session. + QVariantMap hints; + hints["desktop-entry"] = "qBittorrent"; + QDBusPendingReply reply = notifications.Notify("qBittorrent", 0, "qbittorrent", title, + msg, QStringList(), hints, -1); + reply.waitForFinished(); + if (!reply.isError()) + return; #endif - if (systrayIcon && QSystemTrayIcon::supportsMessages()) - systrayIcon->showMessage(title, msg, QSystemTrayIcon::Information, TIME_TRAY_BALLOON); + if (systrayIcon && QSystemTrayIcon::supportsMessages()) + systrayIcon->showMessage(title, msg, QSystemTrayIcon::Information, TIME_TRAY_BALLOON); } /***************************************************** - * * - * Utils * - * * - *****************************************************/ - -void MainWindow::downloadFromURLList(const QStringList& url_list) { - Preferences* const pref = Preferences::instance(); - const bool useTorrentAdditionDialog = pref->useAdditionDialog(); - foreach (QString url, url_list) { - if (url.startsWith("bc://bt/", Qt::CaseInsensitive)) { - qDebug("Converting bc link to magnet link"); - url = misc::bcLinkToMagnet(url); - } - if ((url.size() == 40 && !url.contains(QRegExp("[^0-9A-Fa-f]"))) - || (url.size() == 32 && !url.contains(QRegExp("[^2-7A-Za-z]")))) { - url = "magnet:?xt=urn:btih:" + url; - } - if (url.startsWith("magnet:", Qt::CaseInsensitive)) { - if (useTorrentAdditionDialog) - AddNewTorrentDialog::showMagnet(url, this); - else - QBtSession::instance()->addMagnetUri(url); - } - else if (url.startsWith("http://", Qt::CaseInsensitive) || url.startsWith("https://", Qt::CaseInsensitive) - || url.startsWith("ftp://", Qt::CaseInsensitive)) { - QBtSession::instance()->downloadFromUrl(url); +* * +* Utils * +* * +*****************************************************/ + +void MainWindow::downloadFromURLList(const QStringList& url_list) +{ + Preferences* const pref = Preferences::instance(); + const bool useTorrentAdditionDialog = pref->useAdditionDialog(); + foreach (QString url, url_list) { + if (url.startsWith("bc://bt/", Qt::CaseInsensitive)) { + qDebug("Converting bc link to magnet link"); + url = misc::bcLinkToMagnet(url); + } + if ((url.size() == 40 && !url.contains(QRegExp("[^0-9A-Fa-f]"))) + || (url.size() == 32 && !url.contains(QRegExp("[^2-7A-Za-z]")))) + url = "magnet:?xt=urn:btih:" + url; + if (url.startsWith("magnet:", Qt::CaseInsensitive)) { + if (useTorrentAdditionDialog) + AddNewTorrentDialog::showMagnet(url, this); + else + QBtSession::instance()->addMagnetUri(url); + } + else if (url.startsWith("http://", Qt::CaseInsensitive) || url.startsWith("https://", Qt::CaseInsensitive) + || url.startsWith("ftp://", Qt::CaseInsensitive)) { + QBtSession::instance()->downloadFromUrl(url); + } } - } } /***************************************************** - * * - * Options * - * * - *****************************************************/ - -void MainWindow::createSystrayDelayed() { - static int timeout = 20; - if (QSystemTrayIcon::isSystemTrayAvailable()) { - // Ok, systray integration is now supported - // Create systray icon - createTrayIcon(); - delete systrayCreator; - } else { - if (timeout) { - // Retry a bit later - systrayCreator->start(2000); - --timeout; - } else { - // Timed out, apparently system really does not - // support systray icon - delete systrayCreator; - // Disable it in program preferences to - // avoid trying at earch startup - Preferences::instance()->setSystrayIntegration(false); +* * +* Options * +* * +*****************************************************/ + +void MainWindow::createSystrayDelayed() +{ + static int timeout = 20; + if (QSystemTrayIcon::isSystemTrayAvailable()) { + // Ok, systray integration is now supported + // Create systray icon + createTrayIcon(); + delete systrayCreator; + } + else { + if (timeout) { + // Retry a bit later + systrayCreator->start(2000); + --timeout; + } + else { + // Timed out, apparently system really does not + // support systray icon + delete systrayCreator; + // Disable it in program preferences to + // avoid trying at earch startup + Preferences::instance()->setSystrayIntegration(false); + } } - } } -void MainWindow::updateAltSpeedsBtn(bool alternative) { - actionUse_alternative_speed_limits->setChecked(alternative); +void MainWindow::updateAltSpeedsBtn(bool alternative) +{ + actionUse_alternative_speed_limits->setChecked(alternative); } void MainWindow::updateTrayIconMenu() { - actionToggleVisibility->setText(isVisible() ? tr("Hide") : tr("Show")); + actionToggleVisibility->setText(isVisible() ? tr("Hide") : tr("Show")); } -QMenu* MainWindow::getTrayIconMenu() { - if (myTrayIconMenu) +QMenu* MainWindow::getTrayIconMenu() +{ + if (myTrayIconMenu) + return myTrayIconMenu; + // Tray icon Menu + myTrayIconMenu = new QMenu(this); + connect(myTrayIconMenu, SIGNAL(aboutToShow()), SLOT(updateTrayIconMenu())); + myTrayIconMenu->addAction(actionToggleVisibility); + myTrayIconMenu->addSeparator(); + myTrayIconMenu->addAction(actionOpen); + //myTrayIconMenu->addAction(actionDownload_from_URL); + myTrayIconMenu->addSeparator(); + const bool isAltBWEnabled = Preferences::instance()->isAltBandwidthEnabled(); + updateAltSpeedsBtn(isAltBWEnabled); + actionUse_alternative_speed_limits->setChecked(isAltBWEnabled); + myTrayIconMenu->addAction(actionUse_alternative_speed_limits); + myTrayIconMenu->addAction(actionSet_global_download_limit); + myTrayIconMenu->addAction(actionSet_global_upload_limit); + myTrayIconMenu->addSeparator(); + myTrayIconMenu->addAction(actionStart_All); + myTrayIconMenu->addAction(actionPause_All); + myTrayIconMenu->addSeparator(); + myTrayIconMenu->addAction(actionExit); + if (ui_locked) + myTrayIconMenu->setEnabled(false); return myTrayIconMenu; - // Tray icon Menu - myTrayIconMenu = new QMenu(this); - connect(myTrayIconMenu, SIGNAL(aboutToShow()), SLOT(updateTrayIconMenu())); - myTrayIconMenu->addAction(actionToggleVisibility); - myTrayIconMenu->addSeparator(); - myTrayIconMenu->addAction(actionOpen); - //myTrayIconMenu->addAction(actionDownload_from_URL); - myTrayIconMenu->addSeparator(); - const bool isAltBWEnabled = Preferences::instance()->isAltBandwidthEnabled(); - updateAltSpeedsBtn(isAltBWEnabled); - actionUse_alternative_speed_limits->setChecked(isAltBWEnabled); - myTrayIconMenu->addAction(actionUse_alternative_speed_limits); - myTrayIconMenu->addAction(actionSet_global_download_limit); - myTrayIconMenu->addAction(actionSet_global_upload_limit); - myTrayIconMenu->addSeparator(); - myTrayIconMenu->addAction(actionStart_All); - myTrayIconMenu->addAction(actionPause_All); - myTrayIconMenu->addSeparator(); - myTrayIconMenu->addAction(actionExit); - if (ui_locked) - myTrayIconMenu->setEnabled(false); - return myTrayIconMenu; } -void MainWindow::createTrayIcon() { - // Tray icon - systrayIcon = new QSystemTrayIcon(getSystrayIcon(), this); +void MainWindow::createTrayIcon() +{ + // Tray icon + systrayIcon = new QSystemTrayIcon(getSystrayIcon(), this); - systrayIcon->setContextMenu(getTrayIconMenu()); - connect(systrayIcon, SIGNAL(messageClicked()), this, SLOT(balloonClicked())); - // End of Icon Menu - connect(systrayIcon, SIGNAL(activated(QSystemTrayIcon::ActivationReason)), this, SLOT(toggleVisibility(QSystemTrayIcon::ActivationReason))); - systrayIcon->show(); + systrayIcon->setContextMenu(getTrayIconMenu()); + connect(systrayIcon, SIGNAL(messageClicked()), this, SLOT(balloonClicked())); + // End of Icon Menu + connect(systrayIcon, SIGNAL(activated(QSystemTrayIcon::ActivationReason)), this, SLOT(toggleVisibility(QSystemTrayIcon::ActivationReason))); + systrayIcon->show(); } // Display Program Options -void MainWindow::on_actionOptions_triggered() { - if (options) { - // Get focus - options->setFocus(); - } else { - options = new options_imp(this); - connect(options, SIGNAL(status_changed()), this, SLOT(optionsSaved())); - } -} - -void MainWindow::on_actionTop_tool_bar_triggered() { - bool is_visible = static_cast(sender())->isChecked(); - toolBar->setVisible(is_visible); - Preferences::instance()->setToolbarDisplayed(is_visible); -} - -void MainWindow::on_actionSpeed_in_title_bar_triggered() { - displaySpeedInTitle = static_cast(sender())->isChecked(); - Preferences::instance()->showSpeedInTitleBar(displaySpeedInTitle); - if (displaySpeedInTitle) - updateGUI(); - else - setWindowTitle(QString("qBittorrent %1").arg(QString::fromUtf8(VERSION))); +void MainWindow::on_actionOptions_triggered() +{ + if (options) { + // Get focus + options->setFocus(); + } + else { + options = new options_imp(this); + connect(options, SIGNAL(status_changed()), this, SLOT(optionsSaved())); + } +} + +void MainWindow::on_actionTop_tool_bar_triggered() +{ + bool is_visible = static_cast(sender())->isChecked(); + toolBar->setVisible(is_visible); + Preferences::instance()->setToolbarDisplayed(is_visible); } -void MainWindow::on_actionRSS_Reader_triggered() { - Preferences::instance()->setRSSEnabled(actionRSS_Reader->isChecked()); - displayRSSTab(actionRSS_Reader->isChecked()); +void MainWindow::on_actionSpeed_in_title_bar_triggered() +{ + displaySpeedInTitle = static_cast(sender())->isChecked(); + Preferences::instance()->showSpeedInTitleBar(displaySpeedInTitle); + if (displaySpeedInTitle) + updateGUI(); + else + setWindowTitle(QString("qBittorrent %1").arg(QString::fromUtf8(VERSION))); } -void MainWindow::on_actionSearch_engine_triggered() { +void MainWindow::on_actionRSS_Reader_triggered() +{ + Preferences::instance()->setRSSEnabled(actionRSS_Reader->isChecked()); + displayRSSTab(actionRSS_Reader->isChecked()); +} + +void MainWindow::on_actionSearch_engine_triggered() +{ #ifdef Q_OS_WIN - if (!has_python && actionSearch_engine->isChecked()) { - bool res = false; + if (!has_python && actionSearch_engine->isChecked()) { + bool res = false; - // Check if python is already in PATH - if (misc::pythonVersion() > 0) - res = true; - else - res = addPythonPathToEnv(); - - if (res) - has_python = true; - else if (QMessageBox::question(this, tr("Missing Python Interpreter"), - tr("Python 2.x is required to use the search engine but it does not seem to be installed.\nDo you want to install it now?"), - QMessageBox::Yes|QMessageBox::No, QMessageBox::Yes) == QMessageBox::Yes) { - // Download and Install Python - installPython(); - actionSearch_engine->setChecked(false); - Preferences::instance()->setSearchEnabled(false); - return; - } - else { - actionSearch_engine->setChecked(false); - Preferences::instance()->setSearchEnabled(false); - return; + // Check if python is already in PATH + if (misc::pythonVersion() > 0) + res = true; + else + res = addPythonPathToEnv(); + + if (res) { + has_python = true; + } + else if (QMessageBox::question(this, tr("Missing Python Interpreter"), + tr("Python 2.x is required to use the search engine but it does not seem to be installed.\nDo you want to install it now?"), + QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes) == QMessageBox::Yes) { + // Download and Install Python + installPython(); + actionSearch_engine->setChecked(false); + Preferences::instance()->setSearchEnabled(false); + return; + } + else { + actionSearch_engine->setChecked(false); + Preferences::instance()->setSearchEnabled(false); + return; + } } - } #endif - displaySearchTab(actionSearch_engine->isChecked()); + displaySearchTab(actionSearch_engine->isChecked()); } void MainWindow::on_action_Import_Torrent_triggered() { - TorrentImportDlg::importTorrent(); + TorrentImportDlg::importTorrent(); } /***************************************************** - * * - * HTTP Downloader * - * * - *****************************************************/ +* * +* HTTP Downloader * +* * +*****************************************************/ // Display an input dialog to prompt user for // an url -void MainWindow::on_actionDownload_from_URL_triggered() { - if (!downloadFromURLDialog) { - downloadFromURLDialog = new downloadFromURL(this); - connect(downloadFromURLDialog, SIGNAL(urlsReadyToBeDownloaded(QStringList)), this, SLOT(downloadFromURLList(QStringList))); - } +void MainWindow::on_actionDownload_from_URL_triggered() +{ + if (!downloadFromURLDialog) { + downloadFromURLDialog = new downloadFromURL(this); + connect(downloadFromURLDialog, SIGNAL(urlsReadyToBeDownloaded(QStringList)), this, SLOT(downloadFromURLList(QStringList))); + } } #if defined(Q_OS_WIN) || defined(Q_OS_MAC) void MainWindow::handleUpdateCheckFinished(bool update_available, QString new_version, bool invokedByUser) { - QMessageBox::StandardButton answer = QMessageBox::Yes; - if (update_available) { - answer = QMessageBox::question(this, tr("A new version is available"), - tr("A new version of qBittorrent is available on Sourceforge.\nWould you like to update qBittorrent to version %1?").arg(new_version), - QMessageBox::Yes|QMessageBox::No, QMessageBox::Yes); - if (answer == QMessageBox::Yes) { - // The user want to update, let's download the update - ProgramUpdater* updater = dynamic_cast(sender()); - updater->updateProgram(); + QMessageBox::StandardButton answer = QMessageBox::Yes; + if (update_available) { + answer = QMessageBox::question(this, tr("A new version is available"), + tr("A new version of qBittorrent is available on Sourceforge.\nWould you like to update qBittorrent to version %1?").arg(new_version), + QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes); + if (answer == QMessageBox::Yes) { + // The user want to update, let's download the update + ProgramUpdater* updater = dynamic_cast(sender()); + updater->updateProgram(); + } } - } - else if (invokedByUser) { - QMessageBox::information(this, tr("There isn't a new version available"), - tr("There isn't a new version of qBittorrent available on Sourceforge")); - } - sender()->deleteLater(); - actionCheck_for_updates->setEnabled(true); - actionCheck_for_updates->setText(tr("Check for updates")); - actionCheck_for_updates->setToolTip(tr("Check for program updates")); - // Don't bother the user again in this session if he chose to ignore the update - if (Preferences::instance()->isUpdateCheckEnabled() && answer == QMessageBox::Yes) - programUpdateTimer.start(); + else if (invokedByUser) { + QMessageBox::information(this, tr("There isn't a new version available"), + tr("There isn't a new version of qBittorrent available on Sourceforge")); + } + sender()->deleteLater(); + actionCheck_for_updates->setEnabled(true); + actionCheck_for_updates->setText(tr("Check for updates")); + actionCheck_for_updates->setToolTip(tr("Check for program updates")); + // Don't bother the user again in this session if he chose to ignore the update + if (Preferences::instance()->isUpdateCheckEnabled() && answer == QMessageBox::Yes) + programUpdateTimer.start(); } #endif void MainWindow::on_actionDonate_money_triggered() { - QDesktopServices::openUrl(QUrl("http://sourceforge.net/donate/index.php?group_id=163414")); + QDesktopServices::openUrl(QUrl("http://sourceforge.net/donate/index.php?group_id=163414")); } void MainWindow::showConnectionSettings() { - on_actionOptions_triggered(); - options->showConnectionTab(); + on_actionOptions_triggered(); + options->showConnectionTab(); } void MainWindow::minimizeWindow() @@ -1451,143 +1510,147 @@ void MainWindow::minimizeWindow() void MainWindow::on_actionExecution_Logs_triggered(bool checked) { - if (checked) { - Q_ASSERT(!m_executionLog); - m_executionLog = new ExecutionLog(tabs); - int index_tab = tabs->addTab(m_executionLog, tr("Execution Log")); - tabs->setTabIcon(index_tab, IconProvider::instance()->getIcon("view-calendar-journal")); - } else { - if (m_executionLog) - delete m_executionLog; - } - Preferences::instance()->setExecutionLogEnabled(checked); + if (checked) { + Q_ASSERT(!m_executionLog); + m_executionLog = new ExecutionLog(tabs); + int index_tab = tabs->addTab(m_executionLog, tr("Execution Log")); + tabs->setTabIcon(index_tab, IconProvider::instance()->getIcon("view-calendar-journal")); + } + else if (m_executionLog) + delete m_executionLog; + Preferences::instance()->setExecutionLogEnabled(checked); } void MainWindow::on_actionAutoExit_qBittorrent_toggled(bool enabled) { - qDebug() << Q_FUNC_INFO << enabled; - Preferences::instance()->setShutdownqBTWhenDownloadsComplete(enabled); + qDebug() << Q_FUNC_INFO << enabled; + Preferences::instance()->setShutdownqBTWhenDownloadsComplete(enabled); } void MainWindow::on_actionAutoSuspend_system_toggled(bool enabled) { - qDebug() << Q_FUNC_INFO << enabled; - Preferences::instance()->setSuspendWhenDownloadsComplete(enabled); + qDebug() << Q_FUNC_INFO << enabled; + Preferences::instance()->setSuspendWhenDownloadsComplete(enabled); } -void MainWindow::on_actionAutoHibernate_system_toggled(bool enabled) { - qDebug() << Q_FUNC_INFO << enabled; - Preferences::instance()->setHibernateWhenDownloadsComplete(enabled); +void MainWindow::on_actionAutoHibernate_system_toggled(bool enabled) +{ + qDebug() << Q_FUNC_INFO << enabled; + Preferences::instance()->setHibernateWhenDownloadsComplete(enabled); } void MainWindow::on_actionAutoShutdown_system_toggled(bool enabled) { - qDebug() << Q_FUNC_INFO << enabled; - Preferences::instance()->setShutdownWhenDownloadsComplete(enabled); + qDebug() << Q_FUNC_INFO << enabled; + Preferences::instance()->setShutdownWhenDownloadsComplete(enabled); } void MainWindow::checkForActiveTorrents() { - m_pwr->setActivityState(transferList->getSourceModel()->inhibitSystem()); + m_pwr->setActivityState(transferList->getSourceModel()->inhibitSystem()); } QIcon MainWindow::getSystrayIcon() const { #if (defined(Q_OS_UNIX) && !defined(Q_OS_MAC)) - TrayIcon::Style style = Preferences::instance()->trayIconStyle(); - switch(style) { - case TrayIcon::MONO_DARK: - return QIcon(":/Icons/skin/qbittorrent_mono_dark.png"); - case TrayIcon::MONO_LIGHT: - return QIcon(":/Icons/skin/qbittorrent_mono_light.png"); - default: - break; - } + TrayIcon::Style style = Preferences::instance()->trayIconStyle(); + switch(style) { + case TrayIcon::MONO_DARK: + return QIcon(":/Icons/skin/qbittorrent_mono_dark.png"); + case TrayIcon::MONO_LIGHT: + return QIcon(":/Icons/skin/qbittorrent_mono_light.png"); + default: + break; + } #endif - QIcon icon; + QIcon icon; #if (defined(Q_OS_UNIX) && !defined(Q_OS_MAC)) - if (Preferences::instance()->useSystemIconTheme()) { - icon = QIcon::fromTheme("qbittorrent"); - } + if (Preferences::instance()->useSystemIconTheme()) + icon = QIcon::fromTheme("qbittorrent"); + #endif - if (icon.isNull()) { - icon.addFile(":/Icons/skin/qbittorrent22.png", QSize(22, 22)); - icon.addFile(":/Icons/skin/qbittorrent16.png", QSize(16, 16)); - icon.addFile(":/Icons/skin/qbittorrent32.png", QSize(32, 32)); - } - return icon; + if (icon.isNull()) { + icon.addFile(":/Icons/skin/qbittorrent22.png", QSize(22, 22)); + icon.addFile(":/Icons/skin/qbittorrent16.png", QSize(16, 16)); + icon.addFile(":/Icons/skin/qbittorrent32.png", QSize(32, 32)); + } + return icon; } #if defined(Q_OS_WIN) || defined(Q_OS_MAC) -void MainWindow::checkProgramUpdate() { - programUpdateTimer.stop(); // If the user had clicked the menu item - actionCheck_for_updates->setEnabled(false); - actionCheck_for_updates->setText(tr("Checking for updates...")); - actionCheck_for_updates->setToolTip(tr("Already checking for program updates in the background")); - bool invokedByUser = actionCheck_for_updates == qobject_cast(sender()); - ProgramUpdater *updater = new ProgramUpdater(this, invokedByUser); - connect(updater, SIGNAL(updateCheckFinished(bool, QString, bool)), SLOT(handleUpdateCheckFinished(bool, QString, bool))); - updater->checkForUpdates(); +void MainWindow::checkProgramUpdate() +{ + programUpdateTimer.stop(); // If the user had clicked the menu item + actionCheck_for_updates->setEnabled(false); + actionCheck_for_updates->setText(tr("Checking for updates...")); + actionCheck_for_updates->setToolTip(tr("Already checking for program updates in the background")); + bool invokedByUser = actionCheck_for_updates == qobject_cast(sender()); + ProgramUpdater *updater = new ProgramUpdater(this, invokedByUser); + connect(updater, SIGNAL(updateCheckFinished(bool, QString, bool)), SLOT(handleUpdateCheckFinished(bool, QString, bool))); + updater->checkForUpdates(); } #endif #ifdef Q_OS_WIN -bool MainWindow::addPythonPathToEnv() { - if (has_python) - return true; - QString python_path = Preferences::getPythonPath(); - if (!python_path.isEmpty()) { - // Add it to PATH envvar - QString path_envar = QString::fromLocal8Bit(qgetenv("PATH").constData()); - if (path_envar.isNull()) { - path_envar = ""; +bool MainWindow::addPythonPathToEnv() +{ + if (has_python) + return true; + QString python_path = Preferences::getPythonPath(); + if (!python_path.isEmpty()) { + // Add it to PATH envvar + QString path_envar = QString::fromLocal8Bit(qgetenv("PATH").constData()); + if (path_envar.isNull()) + path_envar = ""; + path_envar = python_path + ";" + path_envar; + qDebug("New PATH envvar is: %s", qPrintable(path_envar)); + qputenv("PATH", fsutils::toNativePath(path_envar).toLocal8Bit()); + return true; } - path_envar = python_path+";"+path_envar; - qDebug("New PATH envvar is: %s", qPrintable(path_envar)); - qputenv("PATH", fsutils::toNativePath(path_envar).toLocal8Bit()); - return true; - } - return false; -} - -void MainWindow::installPython() { - setCursor(QCursor(Qt::WaitCursor)); - // Download python - DownloadThread *pydownloader = new DownloadThread(this); - connect(pydownloader, SIGNAL(downloadFinished(QString,QString)), this, SLOT(pythonDownloadSuccess(QString,QString))); - connect(pydownloader, SIGNAL(downloadFailure(QString,QString)), this, SLOT(pythonDownloadFailure(QString,QString))); - pydownloader->downloadUrl("http://python.org/ftp/python/2.7.3/python-2.7.3.msi"); -} - -void MainWindow::pythonDownloadSuccess(QString url, QString file_path) { - setCursor(QCursor(Qt::ArrowCursor)); - Q_UNUSED(url); - QFile::rename(file_path, file_path+".msi"); - QProcess installer; - qDebug("Launching Python installer in passive mode..."); - - installer.start("msiexec.exe /passive /i " + fsutils::toNativePath(file_path) + ".msi"); - // Wait for setup to complete - installer.waitForFinished(); - - qDebug("Installer stdout: %s", installer.readAllStandardOutput().data()); - qDebug("Installer stderr: %s", installer.readAllStandardError().data()); - qDebug("Setup should be complete!"); - // Delete temp file - fsutils::forceRemove(file_path); - // Reload search engine - has_python = addPythonPathToEnv(); - if (has_python) { - actionSearch_engine->setChecked(true); - displaySearchTab(true); - } - sender()->deleteLater(); -} - -void MainWindow::pythonDownloadFailure(QString url, QString error) { - Q_UNUSED(url); - setCursor(QCursor(Qt::ArrowCursor)); - QMessageBox::warning(this, tr("Download error"), tr("Python setup could not be downloaded, reason: %1.\nPlease install it manually.").arg(error)); - sender()->deleteLater(); + return false; +} + +void MainWindow::installPython() +{ + setCursor(QCursor(Qt::WaitCursor)); + // Download python + DownloadThread *pydownloader = new DownloadThread(this); + connect(pydownloader, SIGNAL(downloadFinished(QString,QString)), this, SLOT(pythonDownloadSuccess(QString,QString))); + connect(pydownloader, SIGNAL(downloadFailure(QString,QString)), this, SLOT(pythonDownloadFailure(QString,QString))); + pydownloader->downloadUrl("http://python.org/ftp/python/2.7.3/python-2.7.3.msi"); +} + +void MainWindow::pythonDownloadSuccess(QString url, QString file_path) +{ + setCursor(QCursor(Qt::ArrowCursor)); + Q_UNUSED(url); + QFile::rename(file_path, file_path + ".msi"); + QProcess installer; + qDebug("Launching Python installer in passive mode..."); + + installer.start("msiexec.exe /passive /i " + fsutils::toNativePath(file_path) + ".msi"); + // Wait for setup to complete + installer.waitForFinished(); + + qDebug("Installer stdout: %s", installer.readAllStandardOutput().data()); + qDebug("Installer stderr: %s", installer.readAllStandardError().data()); + qDebug("Setup should be complete!"); + // Delete temp file + fsutils::forceRemove(file_path); + // Reload search engine + has_python = addPythonPathToEnv(); + if (has_python) { + actionSearch_engine->setChecked(true); + displaySearchTab(true); + } + sender()->deleteLater(); +} + +void MainWindow::pythonDownloadFailure(QString url, QString error) +{ + Q_UNUSED(url); + setCursor(QCursor(Qt::ArrowCursor)); + QMessageBox::warning(this, tr("Download error"), tr("Python setup could not be downloaded, reason: %1.\nPlease install it manually.").arg(error)); + sender()->deleteLater(); } #endif diff --git a/src/mainwindow.h b/src/mainwindow.h index 4edfdae72..9aa90de24 100644 --- a/src/mainwindow.h +++ b/src/mainwindow.h @@ -66,152 +66,153 @@ class QTabWidget; class QTimer; QT_END_NAMESPACE -class MainWindow : public QMainWindow, private Ui::MainWindow{ - Q_OBJECT +class MainWindow: public QMainWindow, private Ui::MainWindow +{ + Q_OBJECT public: - // Construct / Destruct - MainWindow(QWidget *parent=0, const QStringList& torrentCmdLine = QStringList()); - // Methods - QWidget* getCurrentTabWidget() const; - TransferListWidget* getTransferList() const { return transferList; } - QMenu* getTrayIconMenu(); - PropertiesWidget *getProperties() const { return properties; } + // Construct / Destruct + MainWindow(QWidget *parent = 0, const QStringList& torrentCmdLine = QStringList()); + // Methods + QWidget* getCurrentTabWidget() const; + TransferListWidget* getTransferList() const { return transferList; } + QMenu* getTrayIconMenu(); + PropertiesWidget *getProperties() const { return properties; } public slots: - void trackerAuthenticationRequired(const QTorrentHandle& h); - void setTabText(int index, QString text) const; - void showNotificationBaloon(QString title, QString msg) const; - void downloadFromURLList(const QStringList& urls); - void updateAltSpeedsBtn(bool alternative); - void updateNbTorrents(); - void shutdownCleanUp(); + void trackerAuthenticationRequired(const QTorrentHandle& h); + void setTabText(int index, QString text) const; + void showNotificationBaloon(QString title, QString msg) const; + void downloadFromURLList(const QStringList& urls); + void updateAltSpeedsBtn(bool alternative); + void updateNbTorrents(); + void shutdownCleanUp(); protected slots: - // GUI related slots - void dropEvent(QDropEvent *event); - void dragEnterEvent(QDragEnterEvent *event); - void toggleVisibility(QSystemTrayIcon::ActivationReason e = QSystemTrayIcon::Trigger); - void on_actionAbout_triggered(); - void on_actionStatistics_triggered(); - void on_actionCreate_torrent_triggered(); - void on_actionWebsite_triggered() const; - void on_actionBugReport_triggered() const; - void balloonClicked(); - void writeSettings(); - void readSettings(); - void on_actionExit_triggered(); - void createTrayIcon(); - void fullDiskError(const QTorrentHandle& h, QString msg) const; - void handleDownloadFromUrlFailure(QString, QString) const; - void createSystrayDelayed(); - void tab_changed(int); - void on_actionLock_qBittorrent_triggered(); - void defineUILockPassword(); - void clearUILockPassword(); - bool unlockUI(); - void notifyOfUpdate(QString); - void showConnectionSettings(); - void minimizeWindow(); - void updateTrayIconMenu(); - // Keyboard shortcuts - void createKeyboardShortcuts(); - void displayTransferTab() const; - void displaySearchTab() const; - void displayRSSTab() const; - // Torrent actions - void on_actionSet_global_upload_limit_triggered(); - void on_actionSet_global_download_limit_triggered(); - void on_actionDocumentation_triggered() const; - void on_actionOpen_triggered(); - void updateGUI(); - void loadPreferences(bool configure_session=true); - void processParams(const QString& params); - void processParams(const QStringList& params); - void addTorrent(QString path); - void addUnauthenticatedTracker(const QPair &tracker); - void processDownloadedFiles(QString path, QString url); - void processNewMagnetLink(const QString& link); - void finishedTorrent(const QTorrentHandle& h) const; - void askRecursiveTorrentDownloadConfirmation(const QTorrentHandle &h); - // Options slots - void on_actionOptions_triggered(); - void optionsSaved(); - // HTTP slots - void on_actionDownload_from_URL_triggered(); + // GUI related slots + void dropEvent(QDropEvent *event); + void dragEnterEvent(QDragEnterEvent *event); + void toggleVisibility(QSystemTrayIcon::ActivationReason e = QSystemTrayIcon::Trigger); + void on_actionAbout_triggered(); + void on_actionStatistics_triggered(); + void on_actionCreate_torrent_triggered(); + void on_actionWebsite_triggered() const; + void on_actionBugReport_triggered() const; + void balloonClicked(); + void writeSettings(); + void readSettings(); + void on_actionExit_triggered(); + void createTrayIcon(); + void fullDiskError(const QTorrentHandle& h, QString msg) const; + void handleDownloadFromUrlFailure(QString, QString) const; + void createSystrayDelayed(); + void tab_changed(int); + void on_actionLock_qBittorrent_triggered(); + void defineUILockPassword(); + void clearUILockPassword(); + bool unlockUI(); + void notifyOfUpdate(QString); + void showConnectionSettings(); + void minimizeWindow(); + void updateTrayIconMenu(); + // Keyboard shortcuts + void createKeyboardShortcuts(); + void displayTransferTab() const; + void displaySearchTab() const; + void displayRSSTab() const; + // Torrent actions + void on_actionSet_global_upload_limit_triggered(); + void on_actionSet_global_download_limit_triggered(); + void on_actionDocumentation_triggered() const; + void on_actionOpen_triggered(); + void updateGUI(); + void loadPreferences(bool configure_session = true); + void processParams(const QString& params); + void processParams(const QStringList& params); + void addTorrent(QString path); + void addUnauthenticatedTracker(const QPair &tracker); + void processDownloadedFiles(QString path, QString url); + void processNewMagnetLink(const QString& link); + void finishedTorrent(const QTorrentHandle& h) const; + void askRecursiveTorrentDownloadConfirmation(const QTorrentHandle &h); + // Options slots + void on_actionOptions_triggered(); + void optionsSaved(); + // HTTP slots + void on_actionDownload_from_URL_triggered(); #if defined(Q_OS_WIN) || defined(Q_OS_MAC) - void handleUpdateCheckFinished(bool update_available, QString new_version, bool invokedByUser); + void handleUpdateCheckFinished(bool update_available, QString new_version, bool invokedByUser); #endif protected: - void closeEvent(QCloseEvent *); - void showEvent(QShowEvent *); - bool event(QEvent * event); - void displayRSSTab(bool enable); - void displaySearchTab(bool enable); + void closeEvent(QCloseEvent *); + void showEvent(QShowEvent *); + bool event(QEvent * event); + void displayRSSTab(bool enable); + void displaySearchTab(bool enable); private: - QIcon getSystrayIcon() const; + QIcon getSystrayIcon() const; #ifdef Q_OS_WIN - bool addPythonPathToEnv(); - void installPython(); + bool addPythonPathToEnv(); + void installPython(); private slots: - void pythonDownloadSuccess(QString url, QString file_path); - void pythonDownloadFailure(QString url, QString error); + void pythonDownloadSuccess(QString url, QString file_path); + void pythonDownloadFailure(QString url, QString error); #endif private: - QFileSystemWatcher *executable_watcher; - // Bittorrent - QList > unauthenticated_trackers; // Still needed? - // GUI related - bool m_posInitialized; - QTimer *guiUpdater; - HidableTabWidget *tabs; - StatusBar *status_bar; - QPointer options; - QPointer console; - QPointer aboutDlg; - QPointer statsDlg; - QPointer createTorrentDlg; - QPointer downloadFromURLDialog; - QPointer systrayIcon; - QPointer systrayCreator; - QPointer myTrayIconMenu; - TransferListWidget *transferList; - TransferListFiltersWidget *transferListFilters; - PropertiesWidget *properties; - bool displaySpeedInTitle; - bool force_exit; - bool ui_locked; - bool unlockDlgShowing; - LineEdit *search_filter; - QAction *searchFilterAct; - // Keyboard shortcuts - QShortcut *switchSearchShortcut; - QShortcut *switchSearchShortcut2; - QShortcut *switchTransferShortcut; - QShortcut *switchRSSShortcut; - // Widgets - QAction *prioSeparator; - QAction *prioSeparatorMenu; - QSplitter *hSplitter; - QSplitter *vSplitter; - // Search - QPointer searchEngine; - // RSS - QPointer rssWidget; - // Execution Log - QPointer m_executionLog; - // Power Management - PowerManagement *m_pwr; - QTimer *preventTimer; + QFileSystemWatcher *executable_watcher; + // Bittorrent + QList > unauthenticated_trackers; // Still needed? + // GUI related + bool m_posInitialized; + QTimer *guiUpdater; + HidableTabWidget *tabs; + StatusBar *status_bar; + QPointer options; + QPointer console; + QPointer aboutDlg; + QPointer statsDlg; + QPointer createTorrentDlg; + QPointer downloadFromURLDialog; + QPointer systrayIcon; + QPointer systrayCreator; + QPointer myTrayIconMenu; + TransferListWidget *transferList; + TransferListFiltersWidget *transferListFilters; + PropertiesWidget *properties; + bool displaySpeedInTitle; + bool force_exit; + bool ui_locked; + bool unlockDlgShowing; + LineEdit *search_filter; + QAction *searchFilterAct; + // Keyboard shortcuts + QShortcut *switchSearchShortcut; + QShortcut *switchSearchShortcut2; + QShortcut *switchTransferShortcut; + QShortcut *switchRSSShortcut; + // Widgets + QAction *prioSeparator; + QAction *prioSeparatorMenu; + QSplitter *hSplitter; + QSplitter *vSplitter; + // Search + QPointer searchEngine; + // RSS + QPointer rssWidget; + // Execution Log + QPointer m_executionLog; + // Power Management + PowerManagement *m_pwr; + QTimer *preventTimer; #if defined(Q_OS_WIN) || defined(Q_OS_MAC) - QTimer programUpdateTimer; + QTimer programUpdateTimer; #endif #ifdef Q_OS_WIN - bool has_python; + bool has_python; #endif private slots: