Some refactoring and little cleanups.

This commit is contained in:
Martin Rotter 2014-02-02 12:34:32 +01:00
parent ba382fb1a5
commit 0102721ec2
6 changed files with 53 additions and 56 deletions

View File

@ -16,8 +16,6 @@ BaseNetworkAccessManager::~BaseNetworkAccessManager() {
} }
void BaseNetworkAccessManager::loadSettings() { void BaseNetworkAccessManager::loadSettings() {
qDebug("Settings of BaseNetworkAccessManager changed.");
QNetworkProxy new_proxy; QNetworkProxy new_proxy;
QNetworkProxy::ProxyType selected_proxy_type = static_cast<QNetworkProxy::ProxyType>(Settings::instance()->value(APP_CFG_PROXY, QNetworkProxy::ProxyType selected_proxy_type = static_cast<QNetworkProxy::ProxyType>(Settings::instance()->value(APP_CFG_PROXY,
"proxy_type", "proxy_type",
@ -42,6 +40,8 @@ void BaseNetworkAccessManager::loadSettings() {
new_proxy.setPassword(settings->value(APP_CFG_PROXY, new_proxy.setPassword(settings->value(APP_CFG_PROXY,
"password").toString()); "password").toString());
setProxy(new_proxy); setProxy(new_proxy);
qDebug("Settings of BaseNetworkAccessManager loaded.");
} }
QNetworkReply *BaseNetworkAccessManager::createRequest(QNetworkAccessManager::Operation op, QNetworkReply *BaseNetworkAccessManager::createRequest(QNetworkAccessManager::Operation op,

View File

@ -93,48 +93,10 @@ void FeedMessageViewer::quitDownloader() {
qDebug("Quitting feed downloader thread."); qDebug("Quitting feed downloader thread.");
m_feedDownloaderThread->quit(); m_feedDownloaderThread->quit();
qDebug("Feed downloader thread aborted."); qDebug("Feed downloader thread aborted. Deleting it from memory.");
m_feedDownloader->deleteLater(); m_feedDownloader->deleteLater();
} }
void FeedMessageViewer::updateSelectedFeeds() {
if (SystemFactory::instance()->applicationCloseLock()->tryLock()) {
emit feedsUpdateRequested(m_feedsView->selectedFeeds());
}
else {
if (SystemTrayIcon::isSystemTrayActivated()) {
SystemTrayIcon::instance()->showMessage(tr("Cannot update selected items"),
tr("You cannot update selected items because another feed update is ongoing."),
QSystemTrayIcon::Warning);
}
else {
MessageBox::show(this,
QMessageBox::Warning,
tr("Cannot update selected items"),
tr("You cannot update selected items because another feed update is ongoing."));
}
}
}
void FeedMessageViewer::updateAllFeeds() {
if (SystemFactory::instance()->applicationCloseLock()->tryLock()) {
emit feedsUpdateRequested(m_feedsView->allFeeds());
}
else {
if (SystemTrayIcon::isSystemTrayActivated()) {
SystemTrayIcon::instance()->showMessage(tr("Cannot update all items"),
tr("You cannot update all items because another feed update is ongoing."),
QSystemTrayIcon::Warning);
}
else {
MessageBox::show(this,
QMessageBox::Warning,
tr("Cannot update all items"),
tr("You cannot update all items because another feed update is ongoing."));
}
}
}
void FeedMessageViewer::updateCountsOfMessages(int unread_messages, void FeedMessageViewer::updateCountsOfMessages(int unread_messages,
int total_messages) { int total_messages) {
Q_UNUSED(total_messages) Q_UNUSED(total_messages)
@ -196,7 +158,7 @@ void FeedMessageViewer::createConnections() {
// Downloader connections. // Downloader connections.
connect(m_feedDownloaderThread, SIGNAL(finished()), connect(m_feedDownloaderThread, SIGNAL(finished()),
m_feedDownloaderThread, SLOT(deleteLater())); m_feedDownloaderThread, SLOT(deleteLater()));
connect(this, SIGNAL(feedsUpdateRequested(QList<FeedsModelFeed*>)), connect(m_feedsView, SIGNAL(feedsUpdateRequested(QList<FeedsModelFeed*>)),
m_feedDownloader, SLOT(updateFeeds(QList<FeedsModelFeed*>))); m_feedDownloader, SLOT(updateFeeds(QList<FeedsModelFeed*>)));
connect(m_feedDownloader, SIGNAL(finished()), connect(m_feedDownloader, SIGNAL(finished()),
this, SLOT(onFeedUpdatesFinished())); this, SLOT(onFeedUpdatesFinished()));
@ -229,9 +191,9 @@ void FeedMessageViewer::createConnections() {
connect(FormMain::instance()->m_ui->m_actionClearFeeds, connect(FormMain::instance()->m_ui->m_actionClearFeeds,
SIGNAL(triggered()), m_feedsView, SLOT(clearSelectedFeeds())); SIGNAL(triggered()), m_feedsView, SLOT(clearSelectedFeeds()));
connect(FormMain::instance()->m_ui->m_actionUpdateSelectedFeedsCategories, connect(FormMain::instance()->m_ui->m_actionUpdateSelectedFeedsCategories,
SIGNAL(triggered()), this, SLOT(updateSelectedFeeds())); SIGNAL(triggered()), m_feedsView, SLOT(updateSelectedFeeds()));
connect(FormMain::instance()->m_ui->m_actionUpdateAllFeeds, connect(FormMain::instance()->m_ui->m_actionUpdateAllFeeds,
SIGNAL(triggered()), this, SLOT(updateAllFeeds())); SIGNAL(triggered()), m_feedsView, SLOT(updateAllFeeds()));
connect(FormMain::instance()->m_ui->m_actionAddStandardCategory, connect(FormMain::instance()->m_ui->m_actionAddStandardCategory,
SIGNAL(triggered()), m_feedsView, SLOT(addNewStandardCategory())); SIGNAL(triggered()), m_feedsView, SLOT(addNewStandardCategory()));
connect(FormMain::instance()->m_ui->m_actionAddStandardFeed, connect(FormMain::instance()->m_ui->m_actionAddStandardFeed,

View File

@ -7,13 +7,13 @@
class WebBrowser; class WebBrowser;
class FeedsView;
class MessagesView; class MessagesView;
class FeedsView;
class FeedDownloader; class FeedDownloader;
class FeedsModelFeed;
class QToolBar; class QToolBar;
class QSplitter; class QSplitter;
class QProgressBar; class QProgressBar;
class FeedsModelFeed;
class FeedMessageViewer : public TabContent { class FeedMessageViewer : public TabContent {
Q_OBJECT Q_OBJECT
@ -42,11 +42,6 @@ class FeedMessageViewer : public TabContent {
// Destroys worker/feed downloader thread. // Destroys worker/feed downloader thread.
void quitDownloader(); void quitDownloader();
public slots:
// Feed updating.
void updateSelectedFeeds();
void updateAllFeeds();
protected slots: protected slots:
// Updates counts of messages for example in tray icon. // Updates counts of messages for example in tray icon.
void updateCountsOfMessages(int unread_messages, int total_messages); void updateCountsOfMessages(int unread_messages, int total_messages);
@ -66,9 +61,6 @@ class FeedMessageViewer : public TabContent {
// Sets up connections. // Sets up connections.
void createConnections(); void createConnections();
signals:
void feedsUpdateRequested(QList<FeedsModelFeed*>);
private: private:
QToolBar *m_toolBar; QToolBar *m_toolBar;

View File

@ -64,6 +64,44 @@ FeedsModelFeed *FeedsView::isCurrentIndexFeed() const {
return m_sourceModel->feedForIndex(current_mapped); return m_sourceModel->feedForIndex(current_mapped);
} }
void FeedsView::updateAllFeeds() {
if (SystemFactory::instance()->applicationCloseLock()->tryLock()) {
emit feedsUpdateRequested(allFeeds());
}
else {
if (SystemTrayIcon::isSystemTrayActivated()) {
SystemTrayIcon::instance()->showMessage(tr("Cannot update all items"),
tr("You cannot update all items because another feed update is ongoing."),
QSystemTrayIcon::Warning);
}
else {
MessageBox::show(this,
QMessageBox::Warning,
tr("Cannot update all items"),
tr("You cannot update all items because another feed update is ongoing."));
}
}
}
void FeedsView::updateSelectedFeeds() {
if (SystemFactory::instance()->applicationCloseLock()->tryLock()) {
emit feedsUpdateRequested(selectedFeeds());
}
else {
if (SystemTrayIcon::isSystemTrayActivated()) {
SystemTrayIcon::instance()->showMessage(tr("Cannot update selected items"),
tr("You cannot update selected items because another feed update is ongoing."),
QSystemTrayIcon::Warning);
}
else {
MessageBox::show(this,
QMessageBox::Warning,
tr("Cannot update selected items"),
tr("You cannot update selected items because another feed update is ongoing."));
}
}
}
void FeedsView::setSelectedFeedsClearStatus(int clear) { void FeedsView::setSelectedFeedsClearStatus(int clear) {
m_sourceModel->markFeedsDeleted(selectedFeeds(), clear); m_sourceModel->markFeedsDeleted(selectedFeeds(), clear);
updateCountsOfSelectedFeeds(); updateCountsOfSelectedFeeds();

View File

@ -41,6 +41,10 @@ class FeedsView : public QTreeView {
FeedsModelFeed *isCurrentIndexFeed() const; FeedsModelFeed *isCurrentIndexFeed() const;
public slots: public slots:
// Feed updating.
void updateAllFeeds();
void updateSelectedFeeds();
// Feed read/unread manipulators. // Feed read/unread manipulators.
void markSelectedFeedsReadStatus(int read); void markSelectedFeedsReadStatus(int read);
void markSelectedFeedsRead(); void markSelectedFeedsRead();
@ -102,6 +106,9 @@ class FeedsView : public QTreeView {
void contextMenuEvent(QContextMenuEvent *event); void contextMenuEvent(QContextMenuEvent *event);
signals: signals:
// Emitted if user/application requested updating of some feeds.
void feedsUpdateRequested(const QList<FeedsModelFeed*> feeds);
// Emitted if counts of messages are changed. // Emitted if counts of messages are changed.
void feedCountsChanged(int unread_messages, int total_messages); void feedCountsChanged(int unread_messages, int total_messages);

View File

@ -189,9 +189,7 @@ void FormMain::onAboutToQuit() {
qDebug("Cleaning up resources and saving application state."); qDebug("Cleaning up resources and saving application state.");
m_ui->m_tabWidget->feedMessageViewer()->quitDownloader(); m_ui->m_tabWidget->feedMessageViewer()->quitDownloader();
DatabaseFactory::instance()->saveMemoryDatabase(); DatabaseFactory::instance()->saveMemoryDatabase();
saveSize(); saveSize();
} }