From 327b0eaaf50a32c9258b43226e3e68ac9bcbd8e4 Mon Sep 17 00:00:00 2001 From: Martin Rotter <rotter.martinos@gmail.com> Date: Wed, 12 Nov 2014 16:40:06 +0100 Subject: [PATCH] Definite fix for #103. --- CMakeLists.txt | 4 ++-- src/gui/feedsview.h | 1 + src/gui/formsettings.ui | 8 ++++---- src/gui/messagesview.cpp | 4 ++-- src/gui/messagesview.h | 1 + src/miscellaneous/skinfactory.cpp | 11 +++-------- src/miscellaneous/systemfactory.cpp | 11 +++++++++-- 7 files changed, 22 insertions(+), 18 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index cf6f6b6b2..edfdbf633 100755 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -71,8 +71,8 @@ project(rssguard) set(APP_NAME "RSS Guard") set(APP_LOW_NAME "rssguard") -set(APP_VERSION "2.1") -set(FILE_VERSION "2,1,0,0") +set(APP_VERSION "2.0.5") +set(FILE_VERSION "2,0,5,0") set(APP_AUTHOR "Martin Rotter") set(APP_URL "http://bitbucket.org/skunkos/rssguard") set(APP_URL_ISSUES "http://bitbucket.org/skunkos/rssguard/issues") diff --git a/src/gui/feedsview.h b/src/gui/feedsview.h index 1cbc658fc..cfa377873 100644 --- a/src/gui/feedsview.h +++ b/src/gui/feedsview.h @@ -155,6 +155,7 @@ class FeedsView : public QTreeView { // Handle selections. void selectionChanged(const QItemSelection &selected, const QItemSelection &deselected); + // React on "Del" key. void keyPressEvent(QKeyEvent *event); // Show custom context menu. diff --git a/src/gui/formsettings.ui b/src/gui/formsettings.ui index 83b256042..02a08e8e9 100644 --- a/src/gui/formsettings.ui +++ b/src/gui/formsettings.ui @@ -6,7 +6,7 @@ <rect> <x>0</x> <y>0</y> - <width>928</width> + <width>951</width> <height>498</height> </rect> </property> @@ -478,8 +478,8 @@ Authors of this application are NOT responsible for lost data.</string> <rect> <x>0</x> <y>0</y> - <width>167</width> - <height>219</height> + <width>190</width> + <height>238</height> </rect> </property> <layout class="QFormLayout" name="formLayout"> @@ -1163,7 +1163,7 @@ Authors of this application are NOT responsible for lost data.</string> <item> <widget class="QTabWidget" name="m_tabFeedsMessages"> <property name="currentIndex"> - <number>0</number> + <number>1</number> </property> <widget class="QWidget" name="m_tabFeeds"> <attribute name="title"> diff --git a/src/gui/messagesview.cpp b/src/gui/messagesview.cpp index 42a465274..8a0a6807b 100755 --- a/src/gui/messagesview.cpp +++ b/src/gui/messagesview.cpp @@ -208,14 +208,14 @@ void MessagesView::selectionChanged(const QItemSelection &selected, const QItemS current_index.row(), current_index.column(), mapped_current_index.row(), mapped_current_index.column()); - if (mapped_current_index.isValid() && !selected_rows.isEmpty()) { + if (mapped_current_index.isValid() && selected_rows.count() == 1) { if (!m_batchUnreadSwitch) { // Set this message as read only if current item // wasn't changed by "mark selected messages unread" action. m_sourceModel->setMessageRead(mapped_current_index.row(), 1); } - emit currentMessagesChanged(QList<Message>() << m_sourceModel->messageAt(m_proxyModel->mapToSource(selected_rows.first()).row())); + emit currentMessagesChanged(QList<Message>() << m_sourceModel->messageAt(m_proxyModel->mapToSource(selected_rows.at(0)).row())); } else { emit currentMessagesRemoved(); diff --git a/src/gui/messagesview.h b/src/gui/messagesview.h index adc7337d2..2aadf4395 100755 --- a/src/gui/messagesview.h +++ b/src/gui/messagesview.h @@ -87,6 +87,7 @@ class MessagesView : public QTreeView { // Changes resize mode for all columns. void adjustColumns(); + // Saves current sort state. void saveSortState(int column, Qt::SortOrder order); protected: diff --git a/src/miscellaneous/skinfactory.cpp b/src/miscellaneous/skinfactory.cpp index 329aaeee0..286ba6a7a 100755 --- a/src/miscellaneous/skinfactory.cpp +++ b/src/miscellaneous/skinfactory.cpp @@ -46,8 +46,7 @@ void SkinFactory::loadCurrentSkin() { qDebug("Skin '%s' loaded.", qPrintable(skin_name_from_settings)); } else { - qFatal("Skin '%s' not loaded because its data are corrupted. No skin is loaded now!", - qPrintable(skin_name_from_settings)); + qFatal("Skin '%s' not loaded because its data are corrupted. No skin is loaded now!", qPrintable(skin_name_from_settings)); } } @@ -87,9 +86,7 @@ bool SkinFactory::loadSkinFromData(const Skin &skin) { } if (!raw_data.isEmpty()) { - QString parsed_data = raw_data.replace("##", - APP_SKIN_PATH + '/' + - skin_folder); + QString parsed_data = raw_data.replace("##", APP_SKIN_PATH + '/' + skin_folder); qApp->setStyleSheet(parsed_data); } @@ -101,9 +98,7 @@ void SkinFactory::setCurrentSkinName(const QString &skin_name) { } QString SkinFactory::selectedSkinName() { - return qApp->settings()->value(GROUP(GUI), - "skin", - APP_SKIN_DEFAULT).toString(); + return qApp->settings()->value(GROUP(GUI), "skin", APP_SKIN_DEFAULT).toString(); } Skin SkinFactory::skinInfo(const QString &skin_name, bool *ok) { diff --git a/src/miscellaneous/systemfactory.cpp b/src/miscellaneous/systemfactory.cpp index 5bb3081e3..53ffb339d 100755 --- a/src/miscellaneous/systemfactory.cpp +++ b/src/miscellaneous/systemfactory.cpp @@ -195,6 +195,9 @@ bool SystemFactory::isUpdateNewer(const QString &update_version) { // New version is indeed higher thatn current version. return true; } + else if (new_number < current_number) { + return false; + } } // Versions are either the same or they have unequal sizes. @@ -203,8 +206,12 @@ bool SystemFactory::isUpdateNewer(const QString &update_version) { return false; } else { - // Version are not the same length. New version is really higher if it is longer + its last digit is not 0. - return !new_version_tkn.isEmpty() && new_version_tkn.takeFirst().toInt() != 0; + if (new_version_tkn.isEmpty()) { + return false; + } + else { + return new_version_tkn.join("").toInt() > 0; + } } }