From 25fa981a914c5796b3adc1bda93898830d1a29f7 Mon Sep 17 00:00:00 2001 From: Martin Rotter Date: Sun, 24 Sep 2017 22:58:24 +0200 Subject: [PATCH] Work on loading feeds. --- rssguard.pro | 1708 +++++++++-------- src/miscellaneous/databasequeries.cpp | 32 + src/miscellaneous/databasequeries.h | 1 + src/services/inoreader/inoreaderfeed.cpp | 43 + src/services/inoreader/inoreaderfeed.h | 37 + .../inoreader/inoreaderserviceroot.cpp | 17 +- src/services/inoreader/inoreaderserviceroot.h | 3 +- .../network/inoreadernetworkfactory.cpp | 3 +- 8 files changed, 987 insertions(+), 857 deletions(-) create mode 100644 src/services/inoreader/inoreaderfeed.cpp create mode 100644 src/services/inoreader/inoreaderfeed.h diff --git a/rssguard.pro b/rssguard.pro index 64c848cba..da9e0fd07 100755 --- a/rssguard.pro +++ b/rssguard.pro @@ -1,853 +1,855 @@ -################################################################# -# -# This file is part of RSS Guard. -# -# Copyright (C) 2011-2016 by Martin Rotter -# -# RSS Guard is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# RSS Guard is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with RSS Guard. If not, see . -# -# -# This is RSS Guard compilation script for qmake. -# -# Usage: -# a) DEBUG build for testing. (out of source build type) -# cd ../build-dir -# qmake ../rssguard-dir/rssguard.pro -r CONFIG+=debug PREFIX=./usr -# make -# make install -# -# b) RELEASE build for production use. (out of source build type) -# cd ../build-dir -# qmake ../rssguard-dir/rssguard.pro -r CONFIG+=release PREFIX=./usr -# make -# make install -# -# Variables: -# USE_WEBENGINE - if specified, then QtWebEngine module for internal web browser is used. -# Otherwise simple text component is used and some features will be disabled. -# Default value is "false". If QtWebEngine is installed during compilation, then -# value of this variable is tweaked automatically. -# PREFIX - specifies base folder to which files are copied during "make install" -# step, defaults to "$$OUT_PWD/usr" on Linux and to "$$OUT_PWD/app" on Windows. -# LRELEASE_EXECUTABLE - specifies the name/path of "lrelease" executable, defaults to "lrelease". -# -# -# Other information: -# - supports Windows, Linux, Mac OS X, -# - Qt 5.6.0 and higher is required, -# - Qt 5.9.0 and hiher is recommended, -# - C++ 11 is required. -# -# Authors and contributors: -# - Martin Rotter (project leader), -# - Elbert Pol (huge OS/2-related contributions). -# -################################################################# - -TEMPLATE = app -TARGET = rssguard -DEFINES *= QT_USE_QSTRINGBUILDER - -message(rssguard: Welcome RSS Guard qmake script.) - -lessThan(QT_MAJOR_VERSION, 5)|lessThan(QT_MINOR_VERSION, 8) { - error(rssguard: At least Qt \"5.8.0\" is required!!!) -} - -APP_NAME = "RSS Guard" -APP_LOW_NAME = "rssguard" -APP_LOW_H_NAME = ".rssguard" -APP_AUTHOR = "Martin Rotter" -APP_COPYRIGHT = "(C) 2011-2017 $$APP_AUTHOR" -APP_VERSION = "3.4.3" -APP_LONG_NAME = "$$APP_NAME $$APP_VERSION" -APP_EMAIL = "rotter.martinos@gmail.com" -APP_URL = "https://github.com/martinrotter/rssguard" -APP_URL_ISSUES = "https://github.com/martinrotter/rssguard/issues" -APP_URL_ISSUES_NEW = "https://github.com/martinrotter/rssguard/issues/new" -APP_URL_WIKI = "https://github.com/martinrotter/rssguard/wiki" -APP_USERAGENT = "RSS Guard/$$APP_VERSION (github.com/martinrotter/rssguard)" -APP_DONATE_URL = "https://goo.gl/YFVJ0j" -APP_WIN_ARCH = "win64" - -isEmpty(PREFIX) { - message(rssguard: PREFIX variable is not set. This might indicate error.) - - win32 { - PREFIX = $$OUT_PWD/app - } - - mac { - PREFIX = $$quote($$OUT_PWD/$${APP_NAME}.app) - } - - unix:!mac { - PREFIX = $$OUT_PWD/usr - } -} - -isEmpty(DESTDIR) { - unix:!mac { - DESTDIR = $$OUT_PWD/bin - } -} - -isEmpty(USE_WEBENGINE) { - USE_WEBENGINE = false - message("rssguard: USE_WEBENGINE variable is not set.") - - qtHaveModule(webenginewidgets) { - USE_WEBENGINE = true - message("rssguard: WebEngine component IS installed, enabling it.") - } - else { - USE_WEBENGINE = false - message("rssguard: WebEngine component is probably NOT installed, disabling it.") - } -} - -message(rssguard: Shadow copy build directory \"$$OUT_PWD\".) - -isEmpty(LRELEASE_EXECUTABLE) { - LRELEASE_EXECUTABLE = lrelease - message(rssguard: LRELEASE_EXECUTABLE variable is not set.) -} - -# Custom definitions. -DEFINES += APP_VERSION='"\\\"$$APP_VERSION\\\""' -DEFINES += APP_NAME='"\\\"$$APP_NAME\\\""' -DEFINES += APP_LOW_NAME='"\\\"$$APP_LOW_NAME\\\""' -DEFINES += APP_LOW_H_NAME='"\\\"$$APP_LOW_H_NAME\\\""' -DEFINES += APP_LONG_NAME='"\\\"$$APP_LONG_NAME\\\""' -DEFINES += APP_AUTHOR='"\\\"$$APP_AUTHOR\\\""' -DEFINES += APP_EMAIL='"\\\"$$APP_EMAIL\\\""' -DEFINES += APP_URL='"\\\"$$APP_URL\\\""' -DEFINES += APP_URL_ISSUES='"\\\"$$APP_URL_ISSUES\\\""' -DEFINES += APP_URL_ISSUES_NEW='"\\\"$$APP_URL_ISSUES_NEW\\\""' -DEFINES += APP_URL_WIKI='"\\\"$$APP_URL_WIKI\\\""' -DEFINES += APP_USERAGENT='"\\\"$$APP_USERAGENT\\\""' -DEFINES += APP_DONATE_URL='"\\\"$$APP_DONATE_URL\\\""' -DEFINES += APP_SYSTEM_NAME='"\\\"$$QMAKE_HOST.os\\\""' -DEFINES += APP_SYSTEM_VERSION='"\\\"$$QMAKE_HOST.arch\\\""' - -CODECFORTR = UTF-8 -CODECFORSRC = UTF-8 - -exists(.git) { - APP_REVISION = $$system(git rev-parse --short HEAD) -} - -isEmpty(APP_REVISION) { - APP_REVISION = "" -} - -equals(USE_WEBENGINE, false) { - # Add extra revision naming when building without webengine. - APP_REVISION = $$sprintf('%1-%2', $$APP_REVISION, nowebengine) -} - -DEFINES += APP_REVISION='"\\\"$$APP_REVISION\\\""' - -message(rssguard: RSS Guard version is: \"$$APP_VERSION\".) -message(rssguard: Detected Qt version: \"$$QT_VERSION\".) -message(rssguard: Build destination directory: \"$$DESTDIR\".) -message(rssguard: Prefix directory: \"$$PREFIX\".) -message(rssguard: Build revision: \"$$APP_REVISION\".) -message(rssguard: lrelease executable name: \"$$LRELEASE_EXECUTABLE\".) - -QT += core gui widgets sql network networkauth xml - -CONFIG *= c++11 debug_and_release warn_on -DEFINES *= QT_USE_QSTRINGBUILDER QT_USE_FAST_CONCATENATION QT_USE_FAST_OPERATOR_PLUS UNICODE _UNICODE -VERSION = $$APP_VERSION - -win32 { - # Makes sure we use correct subsystem on Windows. - !contains(QMAKE_TARGET.arch, x86_64) { - message(rssguard: Compilling x86 variant.) - QMAKE_LFLAGS_WINDOWS = /SUBSYSTEM:WINDOWS,5.01 - } else { - message(rssguard: Compilling x86_64 variant.) - QMAKE_LFLAGS_WINDOWS = /SUBSYSTEM:WINDOWS,5.02 - } -} - -DISTFILES += resources/scripts/astyle/.astylerc \ - resources/scripts/uncrustify/uncrustify.cfg - -MOC_DIR = $$OUT_PWD/moc -RCC_DIR = $$OUT_PWD/rcc -UI_DIR = $$OUT_PWD/ui - -equals(USE_WEBENGINE, true) { - message(rssguard: Application will be compiled WITH QtWebEngine module.) - QT += webenginewidgets - DEFINES += USE_WEBENGINE -} -else { - message(rssguard: Application will be compiled without QtWebEngine module. Some features will be disabled.) -} - -# Make needed tweaks for RC file getting generated on Windows. -win32 { - RC_ICONS = resources/graphics/rssguard.ico - QMAKE_TARGET_COMPANY = $$APP_AUTHOR - QMAKE_TARGET_DESCRIPTION = $$APP_NAME - QMAKE_TARGET_COPYRIGHT = $$APP_COPYRIGHT - QMAKE_TARGET_PRODUCT = $$APP_NAME -} - -HEADERS += src/core/feeddownloader.h \ - src/core/feedsmodel.h \ - src/core/feedsproxymodel.h \ - src/core/message.h \ - src/core/messagesmodel.h \ - src/core/messagesproxymodel.h \ - src/definitions/definitions.h \ - src/dynamic-shortcuts/dynamicshortcuts.h \ - src/dynamic-shortcuts/dynamicshortcutswidget.h \ - src/dynamic-shortcuts/shortcutbutton.h \ - src/dynamic-shortcuts/shortcutcatcher.h \ - src/exceptions/applicationexception.h \ - src/exceptions/ioexception.h \ - src/gui/baselineedit.h \ - src/gui/basetoolbar.h \ - src/gui/colorlabel.h \ - src/gui/comboboxwithstatus.h \ - src/gui/dialogs/formabout.h \ - src/gui/dialogs/formaddaccount.h \ - src/gui/dialogs/formbackupdatabasesettings.h \ - src/gui/dialogs/formdatabasecleanup.h \ - src/gui/dialogs/formmain.h \ - src/gui/dialogs/formrestoredatabasesettings.h \ - src/gui/dialogs/formsettings.h \ - src/gui/dialogs/formupdate.h \ - src/gui/edittableview.h \ - src/gui/feedmessageviewer.h \ - src/gui/feedstoolbar.h \ - src/gui/feedsview.h \ - src/gui/labelwithstatus.h \ - src/gui/lineeditwithstatus.h \ - src/gui/messagebox.h \ - src/gui/messagessearchlineedit.h \ - src/gui/messagestoolbar.h \ - src/gui/messagesview.h \ - src/gui/plaintoolbutton.h \ - src/gui/squeezelabel.h \ - src/gui/statusbar.h \ - src/gui/styleditemdelegatewithoutfocus.h \ - src/gui/systemtrayicon.h \ - src/gui/tabbar.h \ - src/gui/tabcontent.h \ - src/gui/tabwidget.h \ - src/gui/timespinbox.h \ - src/gui/toolbareditor.h \ - src/gui/widgetwithstatus.h \ - src/miscellaneous/application.h \ - src/miscellaneous/autosaver.h \ - src/miscellaneous/databasecleaner.h \ - src/miscellaneous/databasefactory.h \ - src/miscellaneous/databasequeries.h \ - src/miscellaneous/debugging.h \ - src/miscellaneous/iconfactory.h \ - src/miscellaneous/iofactory.h \ - src/miscellaneous/localization.h \ - src/miscellaneous/mutex.h \ - src/miscellaneous/settings.h \ - src/miscellaneous/settingsproperties.h \ - src/miscellaneous/simplecrypt/simplecrypt.h \ - src/miscellaneous/skinfactory.h \ - src/miscellaneous/systemfactory.h \ - src/miscellaneous/textfactory.h \ - src/network-web/basenetworkaccessmanager.h \ - src/network-web/downloader.h \ - src/network-web/downloadmanager.h \ - src/network-web/networkfactory.h \ - src/network-web/silentnetworkaccessmanager.h \ - src/network-web/webfactory.h \ - src/qtsingleapplication/qtlocalpeer.h \ - src/qtsingleapplication/qtlockedfile.h \ - src/qtsingleapplication/qtsingleapplication.h \ - src/qtsingleapplication/qtsinglecoreapplication.h \ - src/services/abstract/accountcheckmodel.h \ - src/services/abstract/category.h \ - src/services/abstract/feed.h \ - src/services/abstract/gui/formfeeddetails.h \ - src/services/abstract/recyclebin.h \ - src/services/abstract/rootitem.h \ - src/services/abstract/serviceentrypoint.h \ - src/services/abstract/serviceroot.h \ - src/services/owncloud/definitions.h \ - src/services/owncloud/gui/formeditowncloudaccount.h \ - src/services/owncloud/gui/formowncloudfeeddetails.h \ - src/services/owncloud/network/owncloudnetworkfactory.h \ - src/services/owncloud/owncloudfeed.h \ - src/services/owncloud/owncloudserviceentrypoint.h \ - src/services/owncloud/owncloudserviceroot.h \ - src/services/standard/gui/formstandardcategorydetails.h \ - src/services/standard/gui/formstandardfeeddetails.h \ - src/services/standard/gui/formstandardimportexport.h \ - src/services/standard/standardcategory.h \ - src/services/standard/standardfeed.h \ - src/services/standard/standardfeedsimportexportmodel.h \ - src/services/standard/standardserviceentrypoint.h \ - src/services/standard/standardserviceroot.h \ - src/services/tt-rss/definitions.h \ - src/services/tt-rss/gui/formttrssfeeddetails.h \ - src/services/tt-rss/network/ttrssnetworkfactory.h \ - src/services/tt-rss/ttrssfeed.h \ - src/services/tt-rss/ttrssserviceentrypoint.h \ - src/services/tt-rss/ttrssserviceroot.h \ - src/gui/settings/settingspanel.h \ - src/gui/settings/settingsgeneral.h \ - src/gui/settings/settingsdatabase.h \ - src/gui/settings/settingsshortcuts.h \ - src/gui/settings/settingsgui.h \ - src/gui/settings/settingslocalization.h \ - src/gui/settings/settingsbrowsermail.h \ - src/gui/settings/settingsfeedsmessages.h \ - src/gui/settings/settingsdownloads.h \ - src/miscellaneous/feedreader.h \ - src/services/standard/atomparser.h \ - src/services/standard/feedparser.h \ - src/services/standard/rdfparser.h \ - src/services/standard/rssparser.h \ - src/services/abstract/cacheforserviceroot.h \ - src/services/tt-rss/gui/formeditttrssaccount.h \ - src/gui/guiutilities.h \ - src/core/messagesmodelcache.h \ - src/core/messagesmodelsqllayer.h \ - src/gui/treeviewcolumnsmenu.h \ - src/services/abstract/labelsrootitem.h \ - src/services/abstract/label.h \ - src/miscellaneous/externaltool.h \ - src/services/inoreader/definitions.h \ - src/services/inoreader/inoreaderentrypoint.h \ - src/services/inoreader/network/inoreadernetworkfactory.h \ - src/services/inoreader/inoreaderserviceroot.h \ - src/services/inoreader/gui/formeditinoreaderaccount.h - -SOURCES += src/core/feeddownloader.cpp \ - src/core/feedsmodel.cpp \ - src/core/feedsproxymodel.cpp \ - src/core/message.cpp \ - src/core/messagesmodel.cpp \ - src/core/messagesproxymodel.cpp \ - src/dynamic-shortcuts/dynamicshortcuts.cpp \ - src/dynamic-shortcuts/dynamicshortcutswidget.cpp \ - src/dynamic-shortcuts/shortcutbutton.cpp \ - src/dynamic-shortcuts/shortcutcatcher.cpp \ - src/exceptions/applicationexception.cpp \ - src/exceptions/ioexception.cpp \ - src/gui/baselineedit.cpp \ - src/gui/basetoolbar.cpp \ - src/gui/colorlabel.cpp \ - src/gui/comboboxwithstatus.cpp \ - src/gui/dialogs/formabout.cpp \ - src/gui/dialogs/formaddaccount.cpp \ - src/gui/dialogs/formbackupdatabasesettings.cpp \ - src/gui/dialogs/formdatabasecleanup.cpp \ - src/gui/dialogs/formmain.cpp \ - src/gui/dialogs/formrestoredatabasesettings.cpp \ - src/gui/dialogs/formsettings.cpp \ - src/gui/dialogs/formupdate.cpp \ - src/gui/edittableview.cpp \ - src/gui/feedmessageviewer.cpp \ - src/gui/feedstoolbar.cpp \ - src/gui/feedsview.cpp \ - src/gui/labelwithstatus.cpp \ - src/gui/lineeditwithstatus.cpp \ - src/gui/messagebox.cpp \ - src/gui/messagessearchlineedit.cpp \ - src/gui/messagestoolbar.cpp \ - src/gui/messagesview.cpp \ - src/gui/plaintoolbutton.cpp \ - src/gui/squeezelabel.cpp \ - src/gui/statusbar.cpp \ - src/gui/styleditemdelegatewithoutfocus.cpp \ - src/gui/systemtrayicon.cpp \ - src/gui/tabbar.cpp \ - src/gui/tabcontent.cpp \ - src/gui/tabwidget.cpp \ - src/gui/timespinbox.cpp \ - src/gui/toolbareditor.cpp \ - src/gui/widgetwithstatus.cpp \ - src/main.cpp \ - src/miscellaneous/application.cpp \ - src/miscellaneous/autosaver.cpp \ - src/miscellaneous/databasecleaner.cpp \ - src/miscellaneous/databasefactory.cpp \ - src/miscellaneous/databasequeries.cpp \ - src/miscellaneous/debugging.cpp \ - src/miscellaneous/iconfactory.cpp \ - src/miscellaneous/iofactory.cpp \ - src/miscellaneous/localization.cpp \ - src/miscellaneous/mutex.cpp \ - src/miscellaneous/settings.cpp \ - src/miscellaneous/simplecrypt/simplecrypt.cpp \ - src/miscellaneous/skinfactory.cpp \ - src/miscellaneous/systemfactory.cpp \ - src/miscellaneous/textfactory.cpp \ - src/network-web/basenetworkaccessmanager.cpp \ - src/network-web/downloader.cpp \ - src/network-web/downloadmanager.cpp \ - src/network-web/networkfactory.cpp \ - src/network-web/silentnetworkaccessmanager.cpp \ - src/network-web/webfactory.cpp \ - src/qtsingleapplication/qtlocalpeer.cpp \ - src/qtsingleapplication/qtlockedfile.cpp \ - src/qtsingleapplication/qtsingleapplication.cpp \ - src/qtsingleapplication/qtsinglecoreapplication.cpp \ - src/services/abstract/accountcheckmodel.cpp \ - src/services/abstract/category.cpp \ - src/services/abstract/feed.cpp \ - src/services/abstract/gui/formfeeddetails.cpp \ - src/services/abstract/recyclebin.cpp \ - src/services/abstract/rootitem.cpp \ - src/services/abstract/serviceentrypoint.cpp \ - src/services/abstract/serviceroot.cpp \ - src/services/owncloud/gui/formeditowncloudaccount.cpp \ - src/services/owncloud/gui/formowncloudfeeddetails.cpp \ - src/services/owncloud/network/owncloudnetworkfactory.cpp \ - src/services/owncloud/owncloudfeed.cpp \ - src/services/owncloud/owncloudserviceentrypoint.cpp \ - src/services/owncloud/owncloudserviceroot.cpp \ - src/services/standard/gui/formstandardcategorydetails.cpp \ - src/services/standard/gui/formstandardfeeddetails.cpp \ - src/services/standard/gui/formstandardimportexport.cpp \ - src/services/standard/standardcategory.cpp \ - src/services/standard/standardfeed.cpp \ - src/services/standard/standardfeedsimportexportmodel.cpp \ - src/services/standard/standardserviceentrypoint.cpp \ - src/services/standard/standardserviceroot.cpp \ - src/services/tt-rss/gui/formttrssfeeddetails.cpp \ - src/services/tt-rss/network/ttrssnetworkfactory.cpp \ - src/services/tt-rss/ttrssfeed.cpp \ - src/services/tt-rss/ttrssserviceentrypoint.cpp \ - src/services/tt-rss/ttrssserviceroot.cpp \ - src/gui/settings/settingspanel.cpp \ - src/gui/settings/settingsgeneral.cpp \ - src/gui/settings/settingsdatabase.cpp \ - src/gui/settings/settingsshortcuts.cpp \ - src/gui/settings/settingsgui.cpp \ - src/gui/settings/settingslocalization.cpp \ - src/gui/settings/settingsbrowsermail.cpp \ - src/gui/settings/settingsfeedsmessages.cpp \ - src/gui/settings/settingsdownloads.cpp \ - src/miscellaneous/feedreader.cpp \ - src/services/standard/atomparser.cpp \ - src/services/standard/feedparser.cpp \ - src/services/standard/rdfparser.cpp \ - src/services/standard/rssparser.cpp \ - src/services/abstract/cacheforserviceroot.cpp \ - src/services/tt-rss/gui/formeditttrssaccount.cpp \ - src/gui/guiutilities.cpp \ - src/core/messagesmodelcache.cpp \ - src/core/messagesmodelsqllayer.cpp \ - src/gui/treeviewcolumnsmenu.cpp \ - src/services/abstract/labelsrootitem.cpp \ - src/services/abstract/label.cpp \ - src/miscellaneous/externaltool.cpp \ - src/services/inoreader/inoreaderentrypoint.cpp \ - src/services/inoreader/network/inoreadernetworkfactory.cpp \ - src/services/inoreader/inoreaderserviceroot.cpp \ - src/services/inoreader/gui/formeditinoreaderaccount.cpp - -OBJECTIVE_SOURCES += src/miscellaneous/disablewindowtabbing.mm - -FORMS += src/gui/toolbareditor.ui \ - src/network-web/downloaditem.ui \ - src/network-web/downloadmanager.ui \ - src/gui/dialogs/formabout.ui \ - src/gui/dialogs/formaddaccount.ui \ - src/gui/dialogs/formbackupdatabasesettings.ui \ - src/gui/dialogs/formdatabasecleanup.ui \ - src/gui/dialogs/formmain.ui \ - src/gui/dialogs/formrestoredatabasesettings.ui \ - src/gui/dialogs/formsettings.ui \ - src/gui/dialogs/formupdate.ui \ - src/services/abstract/gui/formfeeddetails.ui \ - src/services/owncloud/gui/formeditowncloudaccount.ui \ - src/services/standard/gui/formstandardcategorydetails.ui \ - src/services/standard/gui/formstandardimportexport.ui \ - src/gui/settings/settingsgeneral.ui \ - src/gui/settings/settingsdatabase.ui \ - src/gui/settings/settingsshortcuts.ui \ - src/gui/settings/settingsgui.ui \ - src/gui/settings/settingslocalization.ui \ - src/gui/settings/settingsbrowsermail.ui \ - src/gui/settings/settingsfeedsmessages.ui \ - src/gui/settings/settingsdownloads.ui \ - src/services/tt-rss/gui/formeditttrssaccount.ui \ - src/services/inoreader/gui/formeditinoreaderaccount.ui - -equals(USE_WEBENGINE, true) { - HEADERS += src/gui/locationlineedit.h \ - src/gui/webviewer.h \ - src/gui/webbrowser.h \ - src/gui/discoverfeedsbutton.h \ - src/network-web/googlesuggest.h \ - src/network-web/webpage.h \ - src/network-web/rssguardschemehandler.h - - SOURCES += src/gui/locationlineedit.cpp \ - src/gui/webviewer.cpp \ - src/gui/webbrowser.cpp \ - src/gui/discoverfeedsbutton.cpp \ - src/network-web/googlesuggest.cpp \ - src/network-web/webpage.cpp \ - src/network-web/rssguardschemehandler.cpp - - # Add AdBlock sources. - HEADERS += src/network-web/adblock/adblockaddsubscriptiondialog.h \ - src/network-web/adblock/adblockdialog.h \ - src/network-web/adblock/adblockicon.h \ - src/network-web/adblock/adblockmanager.h \ - src/network-web/adblock/adblockmatcher.h \ - src/network-web/adblock/adblockrule.h \ - src/network-web/adblock/adblocksearchtree.h \ - src/network-web/adblock/adblocksubscription.h \ - src/network-web/adblock/adblocktreewidget.h \ - src/network-web/adblock/adblockurlinterceptor.h \ - src/network-web/urlinterceptor.h \ - src/network-web/networkurlinterceptor.h \ - src/miscellaneous/simpleregexp.h \ - src/gui/treewidget.h - - SOURCES += src/network-web/adblock/adblockaddsubscriptiondialog.cpp \ - src/network-web/adblock/adblockdialog.cpp \ - src/network-web/adblock/adblockicon.cpp \ - src/network-web/adblock/adblockmanager.cpp \ - src/network-web/adblock/adblockmatcher.cpp \ - src/network-web/adblock/adblockrule.cpp \ - src/network-web/adblock/adblocksearchtree.cpp \ - src/network-web/adblock/adblocksubscription.cpp \ - src/network-web/adblock/adblocktreewidget.cpp \ - src/network-web/adblock/adblockurlinterceptor.cpp \ - src/network-web/networkurlinterceptor.cpp \ - src/miscellaneous/simpleregexp.cpp \ - src/gui/treewidget.cpp - - FORMS += src/network-web/adblock/adblockaddsubscriptiondialog.ui \ - src/network-web/adblock/adblockdialog.ui -} -else { - HEADERS += src/gui/messagepreviewer.h \ - src/gui/messagetextbrowser.h \ - src/gui/newspaperpreviewer.h - - SOURCES += src/gui/messagepreviewer.cpp \ - src/gui/messagetextbrowser.cpp \ - src/gui/newspaperpreviewer.cpp - - FORMS += src/gui/messagepreviewer.ui \ - src/gui/newspaperpreviewer.ui -} - -TRANSLATIONS += localization/qtbase_cs.ts \ - localization/qtbase_da.ts \ - localization/qtbase_de.ts \ - localization/qtbase_fr.ts \ - localization/qtbase_he.ts \ - localization/qtbase_it.ts \ - localization/qtbase_ja.ts \ - localization/qtbase_sv.ts \ - localization/rssguard_cs.ts \ - localization/rssguard_da.ts \ - localization/rssguard_de.ts \ - localization/rssguard_en_GB.ts \ - localization/rssguard_en.ts \ - localization/rssguard_es.ts \ - localization/rssguard_fr.ts \ - localization/rssguard_he.ts \ - localization/rssguard_id.ts \ - localization/rssguard_it.ts \ - localization/rssguard_ja.ts \ - localization/rssguard_lt.ts \ - localization/rssguard_nl.ts \ - localization/rssguard_pl.ts \ - localization/rssguard_pt.ts \ - localization/rssguard_sv.ts \ - localization/rssguard_zh.ts - -TRANSLATIONS_WO_QT += $$PWD/localization/rssguard_cs.ts \ - $$PWD/localization/rssguard_da.ts \ - $$PWD/localization/rssguard_de.ts \ - $$PWD/localization/rssguard_en_GB.ts \ - $$PWD/localization/rssguard_en.ts \ - $$PWD/localization/rssguard_es.ts \ - $$PWD/localization/rssguard_fr.ts \ - $$PWD/localization/rssguard_he.ts \ - $$PWD/localization/rssguard_id.ts \ - $$PWD/localization/rssguard_it.ts \ - $$PWD/localization/rssguard_ja.ts \ - $$PWD/localization/rssguard_lt.ts \ - $$PWD/localization/rssguard_nl.ts \ - $$PWD/localization/rssguard_pl.ts \ - $$PWD/localization/rssguard_pt.ts \ - $$PWD/localization/rssguard_sv.ts \ - $$PWD/localization/rssguard_zh.ts - -INCLUDEPATH += $$PWD/. \ - $$PWD/src \ - $$PWD/src/gui \ - $$PWD/src/gui/dialogs \ - $$PWD/src/dynamic-shortcuts - -TEXTS = resources/text/CHANGELOG \ - resources/text/COPYING_BSD \ - resources/text/COPYING_GNU_GPL \ - resources/text/COPYING_GNU_GPL_HTML - -# Make sure QM translations are generated. -lrelease.input = TRANSLATIONS -lrelease.output = $$OUT_PWD/translations/${QMAKE_FILE_BASE}.qm -lrelease.commands = $$LRELEASE_EXECUTABLE -compress ${QMAKE_FILE_IN} -qm $$OUT_PWD/translations/${QMAKE_FILE_BASE}.qm -lrelease.CONFIG += no_link target_predeps - -# Create new "make lupdate" target. -lupdate.target = lupdate -lupdate.commands = lupdate $$shell_path($$PWD/rssguard.pro) -ts $$shell_path($$TRANSLATIONS_WO_QT) - -QMAKE_EXTRA_TARGETS += lupdate -QMAKE_EXTRA_COMPILERS += lrelease - -# Create new "make 7zip" target and "make zip" target. -win32 { - seven_zip.target = 7zip - seven_zip.depends = install - seven_zip.commands = $$shell_path($$shell_quote($$PWD/resources/scripts/7za/7za.exe)) a -t7z $$TARGET-$$APP_VERSION-$$APP_REVISION-$${APP_WIN_ARCH}.7z $$shell_path($$PREFIX/*) - - zip.target = zip - zip.depends = install - zip.commands = $$shell_path($$shell_quote($$PWD/resources/scripts/7za/7za.exe)) a -tzip $$TARGET-$$APP_VERSION-$$APP_REVISION-$${APP_WIN_ARCH}.zip $$shell_path($$PREFIX/*) - - QMAKE_EXTRA_TARGETS += seven_zip zip -} - -unix:!mac { - seven_zip.target = 7zip - seven_zip.depends = install - seven_zip.commands = 7za a -t7z "$$TARGET-$$APP_VERSION-$$APP_REVISION-linux.7z" $$shell_quote($$shell_path($$PREFIX/*)) - - zip.target = zip - zip.depends = install - zip.commands = 7za a -tzip "$$TARGET-$$APP_VERSION-$$APP_REVISION-linux.zip" $$shell_quote($$shell_path($$PREFIX/*)) - - QMAKE_EXTRA_TARGETS += seven_zip zip -} - -mac { - seven_zip.target = 7zip - seven_zip.depends = install - seven_zip.commands = 7za a -t7z "$$TARGET-$$APP_VERSION-$$APP_REVISION-mac.7z" $$shell_quote($$shell_path($$PREFIX)) - - zip.target = zip - zip.depends = install - zip.commands = 7za a -tzip "$$TARGET-$$APP_VERSION-$$APP_REVISION-mac.zip" $$shell_quote($$shell_path($$PREFIX)) - - dmg.target = dmg - dmg.depends = install - dmg.commands = macdeployqt $$shell_quote($$shell_path($$PREFIX)) -dmg - - QMAKE_EXTRA_TARGETS += seven_zip zip dmg -} - -# Create NSIS installer target on Windows. -win32 { - nsis.target = nsis - nsis.depends = install - nsis.commands = \ - $$shell_path($$shell_quote($$PWD/resources/scripts/sed/sed.exe)) -e \"s|@APP_VERSION@|$$APP_VERSION|g; s|@APP_WIN_ARCH@|$$APP_WIN_ARCH|g; s|@APP_REVISION@|$$APP_REVISION|g; s|@APP_NAME@|$$APP_NAME|g; s|@APP_LOW_NAME@|$$APP_LOW_NAME|g; s|@EXE_NAME@|$${APP_LOW_NAME}.exe|g; s|@PWD@|$$replace(PWD, /, \\\\)|g; s|@OUT_PWD@|$$replace(OUT_PWD, /, \\\\)|g\" $$shell_path($$shell_quote($$PWD/resources/nsis/NSIS.definitions.nsh.in)) > $$shell_path($$shell_quote($$OUT_PWD/NSIS.definitions.nsh)) && \ - xcopy /Y $$shell_path($$shell_quote($$PWD/resources/nsis/NSIS.template.in)) $$shell_path($$shell_quote($$OUT_PWD/)) && \ - $$shell_path($$shell_quote($$PWD/resources/scripts/nsis/makensis.exe)) $$shell_path($$shell_quote($$OUT_PWD/NSIS.template.in)) - - QMAKE_EXTRA_TARGETS += nsis -} - -win32 { - windows_all.target = windows_all - windows_all.depends = seven_zip nsis - windows_all.commands = echo "windows_all done..." - - QMAKE_EXTRA_TARGETS += windows_all -} - -# Install all files on Windows. -win32 { - target.path = $$PREFIX - - qt_dlls_root.files = resources/binaries/windows/qt5-msvc2015/*.* - qt_dlls_root.path = $$quote($$PREFIX/) - - qt_dlls_plugins.files = resources/binaries/windows/qt5-msvc2015/* - qt_dlls_plugins.path = $$quote($$PREFIX/) - - misc_sql.files = resources/sql/*.sql - misc_sql.path = $$quote($$PREFIX/sql/) - - misc_icons.files = resources/graphics/misc - misc_icons.path = $$quote($$PREFIX/icons/) - - faenza.files = resources/graphics/Faenza - faenza.path = $$quote($$PREFIX/icons/) - - skins.files = resources/skins - skins.path = $$quote($$PREFIX/) - - feeds.files = resources/initial_feeds - feeds.path = $$quote($$PREFIX/) - - texts.files = $$TEXTS - texts.path = $$quote($$PREFIX/) - - ico.files = resources/graphics/$${TARGET}.ico - ico.path = $$quote($$PREFIX/) - - app_icon.files = resources/graphics/$${TARGET}.png - app_icon.path = $$quote($$PREFIX/) - - app_plain_icon.files = resources/graphics/$${TARGET}_plain.png - app_plain_icon.path = $$quote($$PREFIX/) - - translations.files = $$OUT_PWD/translations - translations.path = $$quote($$PREFIX/) - - INSTALLS += target misc_sql qt_dlls_root qt_dlls_plugins \ - misc_icons faenza skins \ - feeds texts ico app_icon app_plain_icon translations - - equals(USE_WEBENGINE, true) { - # Copy extra resource files for QtWebEngine. - qtwebengine_dlls.files = resources/binaries/windows/qt5-msvc2015-webengine/* - qtwebengine_dlls.path = $$quote($$PREFIX/) - - qtwebengine.files = resources/binaries/windows/qt5-msvc2015-webengine/*.* - qtwebengine.path = $$quote($$PREFIX/) - - INSTALLS += qtwebengine_dlls qtwebengine - } -} - -# Install all files on Linux. -unix:!mac { - target.path = $$PREFIX/bin - - # Install SQL initializers. - misc_sql.files = resources/sql/*.sql - misc_sql.path = $$quote($$PREFIX/share/$$TARGET/sql/) - - # Misc icons. - misc_icons.files = resources/graphics/misc - misc_icons.path = $$quote($$PREFIX/share/$$TARGET/icons/) - - # Initial feeds. - misc_feeds.files = resources/initial_feeds - misc_feeds.path = $$quote($$PREFIX/share/$$TARGET/) - - misc_icon.files = resources/graphics/$${TARGET}.png - misc_icon.path = $$quote($$PREFIX/share/pixmaps/) - - skins.files = resources/skins - skins.path = $$quote($$PREFIX/share/$$TARGET/) - - misc_plain_icon.files = resources/graphics/$${TARGET}_plain.png - misc_plain_icon.path = $$quote($$PREFIX/share/$$TARGET/icons/) - - misc_texts.files = $$TEXTS - misc_texts.path = $$quote($$PREFIX/share/$$TARGET/information/) - - desktop_file.files = resources/desktop/$${TARGET}.desktop - desktop_file.path = $$quote($$PREFIX/share/applications/) - - desktop_file_autostart.files = resources/desktop/$${TARGET}.desktop.autostart - desktop_file_autostart.path = $$quote($$PREFIX/share/$${TARGET}/autostart/) - - translations.files = $$OUT_PWD/translations - translations.path = $$quote($$PREFIX/share/$$TARGET/) - - INSTALLS += target misc_sql misc_icons misc_feeds \ - misc_icon misc_plain_icon skins misc_texts \ - desktop_file desktop_file_autostart translations -} - -mac { - IDENTIFIER = org.$${TARGET}.RSSGuard - CONFIG -= app_bundle - ICON = resources/macosx/$${TARGET}.icns - QMAKE_MAC_SDK = macosx10.12 - QMAKE_MACOSX_DEPLOYMENT_TARGET = 10.7 - LIBS += -framework AppKit - - target.path = $$quote($$PREFIX/Contents/MacOS/) - - # Install app icon. - icns_icon.files = resources/macosx/$${TARGET}.icns - icns_icon.path = $$quote($$PREFIX/Contents/Resources/) - - # Install Info.plist. - info_plist.files = resources/macosx/Info.plist.in - info_plist.path = $$quote($$PREFIX/Contents/) - - # Process the just installed Info.plist. - info_plist2.extra = @sed -e "s,@EXECUTABLE@,$$TARGET,g" -e "s,@SHORT_VERSION@,$$APP_VERSION,g" -e "s,@APP_NAME@,\"$$APP_NAME\",g" -e "s,@ICON@,$$basename(ICON),g" -e "s,@TYPEINFO@,"????",g" $$shell_quote($$PREFIX/Contents/Info.plist.in) > $$shell_quote($$PREFIX/Contents/Info.plist) && \ - rm -f $$shell_quote($$PREFIX/Contents/Info.plist.in) - info_plist2.path = $$quote($$PREFIX/Contents/) - - # Install PkgInfo - pkginfo.extra = @printf "APPL????" > $$shell_quote($$PREFIX/Contents/PkgInfo) - pkginfo.path = $$quote($$PREFIX/Contents/) - - # Install SQL initializers. - misc_sql.files = resources/sql - misc_sql.path = $$quote($$PREFIX/Contents/Resources/) - - # Misc icons. - misc_icons.files = resources/graphics/misc - misc_icons.path = $$quote($$PREFIX/Contents/Resources/icons/) - - faenza.files = resources/graphics/Faenza - faenza.path = $$quote($$PREFIX/Contents/Resources/icons/) - - # Initial feeds. - misc_feeds.files = resources/initial_feeds - misc_feeds.path = $$quote($$PREFIX/Contents/Resources/) - - skins.files = resources/skins - skins.path = $$quote($$PREFIX/Contents/Resources) - - misc_icon.files = resources/graphics/$${TARGET}.png - misc_icon.path = $$quote($$PREFIX/Contents/Resources/icons) - - misc_plain_icon.files = resources/graphics/$${TARGET}_plain.png - misc_plain_icon.path = $$quote($$PREFIX/Contents/Resources/icons/) - - misc_texts.files = $$TEXTS - misc_texts.path = $$quote($$PREFIX/Contents/Resources/information/) - - translations.files = $$OUT_PWD/translations - translations.path = $$quote($$PREFIX/Contents/Resources/) - - INSTALLS += target icns_icon info_plist info_plist2 pkginfo \ - misc_sql misc_icons faenza misc_feeds skins \ - misc_icon misc_plain_icon misc_texts translations - -} - -win32:CONFIG(release, debug|release): LIBS += -L$$PWD/../build-qtnetworkauth-Desktop-Debug/lib/release/ -lQt5NetworkAuth -else:win32:CONFIG(debug, debug|release): LIBS += -L$$PWD/../build-qtnetworkauth-Desktop-Debug/lib/debug/ -lQt5NetworkAuth -else:unix: LIBS += -L$$PWD/../build-qtnetworkauth-Desktop-Debug/lib/ -lQt5NetworkAuth - -INCLUDEPATH += $$PWD/../build-qtnetworkauth-Desktop-Debug/include -DEPENDPATH += $$PWD/../build-qtnetworkauth-Desktop-Debug/include +################################################################# +# +# This file is part of RSS Guard. +# +# Copyright (C) 2011-2016 by Martin Rotter +# +# RSS Guard is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# RSS Guard is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with RSS Guard. If not, see . +# +# +# This is RSS Guard compilation script for qmake. +# +# Usage: +# a) DEBUG build for testing. (out of source build type) +# cd ../build-dir +# qmake ../rssguard-dir/rssguard.pro -r CONFIG+=debug PREFIX=./usr +# make +# make install +# +# b) RELEASE build for production use. (out of source build type) +# cd ../build-dir +# qmake ../rssguard-dir/rssguard.pro -r CONFIG+=release PREFIX=./usr +# make +# make install +# +# Variables: +# USE_WEBENGINE - if specified, then QtWebEngine module for internal web browser is used. +# Otherwise simple text component is used and some features will be disabled. +# Default value is "false". If QtWebEngine is installed during compilation, then +# value of this variable is tweaked automatically. +# PREFIX - specifies base folder to which files are copied during "make install" +# step, defaults to "$$OUT_PWD/usr" on Linux and to "$$OUT_PWD/app" on Windows. +# LRELEASE_EXECUTABLE - specifies the name/path of "lrelease" executable, defaults to "lrelease". +# +# +# Other information: +# - supports Windows, Linux, Mac OS X, +# - Qt 5.6.0 and higher is required, +# - Qt 5.9.0 and hiher is recommended, +# - C++ 11 is required. +# +# Authors and contributors: +# - Martin Rotter (project leader), +# - Elbert Pol (huge OS/2-related contributions). +# +################################################################# + +TEMPLATE = app +TARGET = rssguard +DEFINES *= QT_USE_QSTRINGBUILDER + +message(rssguard: Welcome RSS Guard qmake script.) + +lessThan(QT_MAJOR_VERSION, 5)|lessThan(QT_MINOR_VERSION, 8) { + error(rssguard: At least Qt \"5.8.0\" is required!!!) +} + +APP_NAME = "RSS Guard" +APP_LOW_NAME = "rssguard" +APP_LOW_H_NAME = ".rssguard" +APP_AUTHOR = "Martin Rotter" +APP_COPYRIGHT = "(C) 2011-2017 $$APP_AUTHOR" +APP_VERSION = "3.4.3" +APP_LONG_NAME = "$$APP_NAME $$APP_VERSION" +APP_EMAIL = "rotter.martinos@gmail.com" +APP_URL = "https://github.com/martinrotter/rssguard" +APP_URL_ISSUES = "https://github.com/martinrotter/rssguard/issues" +APP_URL_ISSUES_NEW = "https://github.com/martinrotter/rssguard/issues/new" +APP_URL_WIKI = "https://github.com/martinrotter/rssguard/wiki" +APP_USERAGENT = "RSS Guard/$$APP_VERSION (github.com/martinrotter/rssguard)" +APP_DONATE_URL = "https://goo.gl/YFVJ0j" +APP_WIN_ARCH = "win64" + +isEmpty(PREFIX) { + message(rssguard: PREFIX variable is not set. This might indicate error.) + + win32 { + PREFIX = $$OUT_PWD/app + } + + mac { + PREFIX = $$quote($$OUT_PWD/$${APP_NAME}.app) + } + + unix:!mac { + PREFIX = $$OUT_PWD/usr + } +} + +isEmpty(DESTDIR) { + unix:!mac { + DESTDIR = $$OUT_PWD/bin + } +} + +isEmpty(USE_WEBENGINE) { + USE_WEBENGINE = false + message("rssguard: USE_WEBENGINE variable is not set.") + + qtHaveModule(webenginewidgets) { + USE_WEBENGINE = true + message("rssguard: WebEngine component IS installed, enabling it.") + } + else { + USE_WEBENGINE = false + message("rssguard: WebEngine component is probably NOT installed, disabling it.") + } +} + +message(rssguard: Shadow copy build directory \"$$OUT_PWD\".) + +isEmpty(LRELEASE_EXECUTABLE) { + LRELEASE_EXECUTABLE = lrelease + message(rssguard: LRELEASE_EXECUTABLE variable is not set.) +} + +# Custom definitions. +DEFINES += APP_VERSION='"\\\"$$APP_VERSION\\\""' +DEFINES += APP_NAME='"\\\"$$APP_NAME\\\""' +DEFINES += APP_LOW_NAME='"\\\"$$APP_LOW_NAME\\\""' +DEFINES += APP_LOW_H_NAME='"\\\"$$APP_LOW_H_NAME\\\""' +DEFINES += APP_LONG_NAME='"\\\"$$APP_LONG_NAME\\\""' +DEFINES += APP_AUTHOR='"\\\"$$APP_AUTHOR\\\""' +DEFINES += APP_EMAIL='"\\\"$$APP_EMAIL\\\""' +DEFINES += APP_URL='"\\\"$$APP_URL\\\""' +DEFINES += APP_URL_ISSUES='"\\\"$$APP_URL_ISSUES\\\""' +DEFINES += APP_URL_ISSUES_NEW='"\\\"$$APP_URL_ISSUES_NEW\\\""' +DEFINES += APP_URL_WIKI='"\\\"$$APP_URL_WIKI\\\""' +DEFINES += APP_USERAGENT='"\\\"$$APP_USERAGENT\\\""' +DEFINES += APP_DONATE_URL='"\\\"$$APP_DONATE_URL\\\""' +DEFINES += APP_SYSTEM_NAME='"\\\"$$QMAKE_HOST.os\\\""' +DEFINES += APP_SYSTEM_VERSION='"\\\"$$QMAKE_HOST.arch\\\""' + +CODECFORTR = UTF-8 +CODECFORSRC = UTF-8 + +exists(.git) { + APP_REVISION = $$system(git rev-parse --short HEAD) +} + +isEmpty(APP_REVISION) { + APP_REVISION = "" +} + +equals(USE_WEBENGINE, false) { + # Add extra revision naming when building without webengine. + APP_REVISION = $$sprintf('%1-%2', $$APP_REVISION, nowebengine) +} + +DEFINES += APP_REVISION='"\\\"$$APP_REVISION\\\""' + +message(rssguard: RSS Guard version is: \"$$APP_VERSION\".) +message(rssguard: Detected Qt version: \"$$QT_VERSION\".) +message(rssguard: Build destination directory: \"$$DESTDIR\".) +message(rssguard: Prefix directory: \"$$PREFIX\".) +message(rssguard: Build revision: \"$$APP_REVISION\".) +message(rssguard: lrelease executable name: \"$$LRELEASE_EXECUTABLE\".) + +QT += core gui widgets sql network networkauth xml + +CONFIG *= c++11 debug_and_release warn_on +DEFINES *= QT_USE_QSTRINGBUILDER QT_USE_FAST_CONCATENATION QT_USE_FAST_OPERATOR_PLUS UNICODE _UNICODE +VERSION = $$APP_VERSION + +win32 { + # Makes sure we use correct subsystem on Windows. + !contains(QMAKE_TARGET.arch, x86_64) { + message(rssguard: Compilling x86 variant.) + QMAKE_LFLAGS_WINDOWS = /SUBSYSTEM:WINDOWS,5.01 + } else { + message(rssguard: Compilling x86_64 variant.) + QMAKE_LFLAGS_WINDOWS = /SUBSYSTEM:WINDOWS,5.02 + } +} + +DISTFILES += resources/scripts/astyle/.astylerc \ + resources/scripts/uncrustify/uncrustify.cfg + +MOC_DIR = $$OUT_PWD/moc +RCC_DIR = $$OUT_PWD/rcc +UI_DIR = $$OUT_PWD/ui + +equals(USE_WEBENGINE, true) { + message(rssguard: Application will be compiled WITH QtWebEngine module.) + QT += webenginewidgets + DEFINES += USE_WEBENGINE +} +else { + message(rssguard: Application will be compiled without QtWebEngine module. Some features will be disabled.) +} + +# Make needed tweaks for RC file getting generated on Windows. +win32 { + RC_ICONS = resources/graphics/rssguard.ico + QMAKE_TARGET_COMPANY = $$APP_AUTHOR + QMAKE_TARGET_DESCRIPTION = $$APP_NAME + QMAKE_TARGET_COPYRIGHT = $$APP_COPYRIGHT + QMAKE_TARGET_PRODUCT = $$APP_NAME +} + +HEADERS += src/core/feeddownloader.h \ + src/core/feedsmodel.h \ + src/core/feedsproxymodel.h \ + src/core/message.h \ + src/core/messagesmodel.h \ + src/core/messagesproxymodel.h \ + src/definitions/definitions.h \ + src/dynamic-shortcuts/dynamicshortcuts.h \ + src/dynamic-shortcuts/dynamicshortcutswidget.h \ + src/dynamic-shortcuts/shortcutbutton.h \ + src/dynamic-shortcuts/shortcutcatcher.h \ + src/exceptions/applicationexception.h \ + src/exceptions/ioexception.h \ + src/gui/baselineedit.h \ + src/gui/basetoolbar.h \ + src/gui/colorlabel.h \ + src/gui/comboboxwithstatus.h \ + src/gui/dialogs/formabout.h \ + src/gui/dialogs/formaddaccount.h \ + src/gui/dialogs/formbackupdatabasesettings.h \ + src/gui/dialogs/formdatabasecleanup.h \ + src/gui/dialogs/formmain.h \ + src/gui/dialogs/formrestoredatabasesettings.h \ + src/gui/dialogs/formsettings.h \ + src/gui/dialogs/formupdate.h \ + src/gui/edittableview.h \ + src/gui/feedmessageviewer.h \ + src/gui/feedstoolbar.h \ + src/gui/feedsview.h \ + src/gui/labelwithstatus.h \ + src/gui/lineeditwithstatus.h \ + src/gui/messagebox.h \ + src/gui/messagessearchlineedit.h \ + src/gui/messagestoolbar.h \ + src/gui/messagesview.h \ + src/gui/plaintoolbutton.h \ + src/gui/squeezelabel.h \ + src/gui/statusbar.h \ + src/gui/styleditemdelegatewithoutfocus.h \ + src/gui/systemtrayicon.h \ + src/gui/tabbar.h \ + src/gui/tabcontent.h \ + src/gui/tabwidget.h \ + src/gui/timespinbox.h \ + src/gui/toolbareditor.h \ + src/gui/widgetwithstatus.h \ + src/miscellaneous/application.h \ + src/miscellaneous/autosaver.h \ + src/miscellaneous/databasecleaner.h \ + src/miscellaneous/databasefactory.h \ + src/miscellaneous/databasequeries.h \ + src/miscellaneous/debugging.h \ + src/miscellaneous/iconfactory.h \ + src/miscellaneous/iofactory.h \ + src/miscellaneous/localization.h \ + src/miscellaneous/mutex.h \ + src/miscellaneous/settings.h \ + src/miscellaneous/settingsproperties.h \ + src/miscellaneous/simplecrypt/simplecrypt.h \ + src/miscellaneous/skinfactory.h \ + src/miscellaneous/systemfactory.h \ + src/miscellaneous/textfactory.h \ + src/network-web/basenetworkaccessmanager.h \ + src/network-web/downloader.h \ + src/network-web/downloadmanager.h \ + src/network-web/networkfactory.h \ + src/network-web/silentnetworkaccessmanager.h \ + src/network-web/webfactory.h \ + src/qtsingleapplication/qtlocalpeer.h \ + src/qtsingleapplication/qtlockedfile.h \ + src/qtsingleapplication/qtsingleapplication.h \ + src/qtsingleapplication/qtsinglecoreapplication.h \ + src/services/abstract/accountcheckmodel.h \ + src/services/abstract/category.h \ + src/services/abstract/feed.h \ + src/services/abstract/gui/formfeeddetails.h \ + src/services/abstract/recyclebin.h \ + src/services/abstract/rootitem.h \ + src/services/abstract/serviceentrypoint.h \ + src/services/abstract/serviceroot.h \ + src/services/owncloud/definitions.h \ + src/services/owncloud/gui/formeditowncloudaccount.h \ + src/services/owncloud/gui/formowncloudfeeddetails.h \ + src/services/owncloud/network/owncloudnetworkfactory.h \ + src/services/owncloud/owncloudfeed.h \ + src/services/owncloud/owncloudserviceentrypoint.h \ + src/services/owncloud/owncloudserviceroot.h \ + src/services/standard/gui/formstandardcategorydetails.h \ + src/services/standard/gui/formstandardfeeddetails.h \ + src/services/standard/gui/formstandardimportexport.h \ + src/services/standard/standardcategory.h \ + src/services/standard/standardfeed.h \ + src/services/standard/standardfeedsimportexportmodel.h \ + src/services/standard/standardserviceentrypoint.h \ + src/services/standard/standardserviceroot.h \ + src/services/tt-rss/definitions.h \ + src/services/tt-rss/gui/formttrssfeeddetails.h \ + src/services/tt-rss/network/ttrssnetworkfactory.h \ + src/services/tt-rss/ttrssfeed.h \ + src/services/tt-rss/ttrssserviceentrypoint.h \ + src/services/tt-rss/ttrssserviceroot.h \ + src/gui/settings/settingspanel.h \ + src/gui/settings/settingsgeneral.h \ + src/gui/settings/settingsdatabase.h \ + src/gui/settings/settingsshortcuts.h \ + src/gui/settings/settingsgui.h \ + src/gui/settings/settingslocalization.h \ + src/gui/settings/settingsbrowsermail.h \ + src/gui/settings/settingsfeedsmessages.h \ + src/gui/settings/settingsdownloads.h \ + src/miscellaneous/feedreader.h \ + src/services/standard/atomparser.h \ + src/services/standard/feedparser.h \ + src/services/standard/rdfparser.h \ + src/services/standard/rssparser.h \ + src/services/abstract/cacheforserviceroot.h \ + src/services/tt-rss/gui/formeditttrssaccount.h \ + src/gui/guiutilities.h \ + src/core/messagesmodelcache.h \ + src/core/messagesmodelsqllayer.h \ + src/gui/treeviewcolumnsmenu.h \ + src/services/abstract/labelsrootitem.h \ + src/services/abstract/label.h \ + src/miscellaneous/externaltool.h \ + src/services/inoreader/definitions.h \ + src/services/inoreader/inoreaderentrypoint.h \ + src/services/inoreader/network/inoreadernetworkfactory.h \ + src/services/inoreader/inoreaderserviceroot.h \ + src/services/inoreader/gui/formeditinoreaderaccount.h \ + src/services/inoreader/inoreaderfeed.h + +SOURCES += src/core/feeddownloader.cpp \ + src/core/feedsmodel.cpp \ + src/core/feedsproxymodel.cpp \ + src/core/message.cpp \ + src/core/messagesmodel.cpp \ + src/core/messagesproxymodel.cpp \ + src/dynamic-shortcuts/dynamicshortcuts.cpp \ + src/dynamic-shortcuts/dynamicshortcutswidget.cpp \ + src/dynamic-shortcuts/shortcutbutton.cpp \ + src/dynamic-shortcuts/shortcutcatcher.cpp \ + src/exceptions/applicationexception.cpp \ + src/exceptions/ioexception.cpp \ + src/gui/baselineedit.cpp \ + src/gui/basetoolbar.cpp \ + src/gui/colorlabel.cpp \ + src/gui/comboboxwithstatus.cpp \ + src/gui/dialogs/formabout.cpp \ + src/gui/dialogs/formaddaccount.cpp \ + src/gui/dialogs/formbackupdatabasesettings.cpp \ + src/gui/dialogs/formdatabasecleanup.cpp \ + src/gui/dialogs/formmain.cpp \ + src/gui/dialogs/formrestoredatabasesettings.cpp \ + src/gui/dialogs/formsettings.cpp \ + src/gui/dialogs/formupdate.cpp \ + src/gui/edittableview.cpp \ + src/gui/feedmessageviewer.cpp \ + src/gui/feedstoolbar.cpp \ + src/gui/feedsview.cpp \ + src/gui/labelwithstatus.cpp \ + src/gui/lineeditwithstatus.cpp \ + src/gui/messagebox.cpp \ + src/gui/messagessearchlineedit.cpp \ + src/gui/messagestoolbar.cpp \ + src/gui/messagesview.cpp \ + src/gui/plaintoolbutton.cpp \ + src/gui/squeezelabel.cpp \ + src/gui/statusbar.cpp \ + src/gui/styleditemdelegatewithoutfocus.cpp \ + src/gui/systemtrayicon.cpp \ + src/gui/tabbar.cpp \ + src/gui/tabcontent.cpp \ + src/gui/tabwidget.cpp \ + src/gui/timespinbox.cpp \ + src/gui/toolbareditor.cpp \ + src/gui/widgetwithstatus.cpp \ + src/main.cpp \ + src/miscellaneous/application.cpp \ + src/miscellaneous/autosaver.cpp \ + src/miscellaneous/databasecleaner.cpp \ + src/miscellaneous/databasefactory.cpp \ + src/miscellaneous/databasequeries.cpp \ + src/miscellaneous/debugging.cpp \ + src/miscellaneous/iconfactory.cpp \ + src/miscellaneous/iofactory.cpp \ + src/miscellaneous/localization.cpp \ + src/miscellaneous/mutex.cpp \ + src/miscellaneous/settings.cpp \ + src/miscellaneous/simplecrypt/simplecrypt.cpp \ + src/miscellaneous/skinfactory.cpp \ + src/miscellaneous/systemfactory.cpp \ + src/miscellaneous/textfactory.cpp \ + src/network-web/basenetworkaccessmanager.cpp \ + src/network-web/downloader.cpp \ + src/network-web/downloadmanager.cpp \ + src/network-web/networkfactory.cpp \ + src/network-web/silentnetworkaccessmanager.cpp \ + src/network-web/webfactory.cpp \ + src/qtsingleapplication/qtlocalpeer.cpp \ + src/qtsingleapplication/qtlockedfile.cpp \ + src/qtsingleapplication/qtsingleapplication.cpp \ + src/qtsingleapplication/qtsinglecoreapplication.cpp \ + src/services/abstract/accountcheckmodel.cpp \ + src/services/abstract/category.cpp \ + src/services/abstract/feed.cpp \ + src/services/abstract/gui/formfeeddetails.cpp \ + src/services/abstract/recyclebin.cpp \ + src/services/abstract/rootitem.cpp \ + src/services/abstract/serviceentrypoint.cpp \ + src/services/abstract/serviceroot.cpp \ + src/services/owncloud/gui/formeditowncloudaccount.cpp \ + src/services/owncloud/gui/formowncloudfeeddetails.cpp \ + src/services/owncloud/network/owncloudnetworkfactory.cpp \ + src/services/owncloud/owncloudfeed.cpp \ + src/services/owncloud/owncloudserviceentrypoint.cpp \ + src/services/owncloud/owncloudserviceroot.cpp \ + src/services/standard/gui/formstandardcategorydetails.cpp \ + src/services/standard/gui/formstandardfeeddetails.cpp \ + src/services/standard/gui/formstandardimportexport.cpp \ + src/services/standard/standardcategory.cpp \ + src/services/standard/standardfeed.cpp \ + src/services/standard/standardfeedsimportexportmodel.cpp \ + src/services/standard/standardserviceentrypoint.cpp \ + src/services/standard/standardserviceroot.cpp \ + src/services/tt-rss/gui/formttrssfeeddetails.cpp \ + src/services/tt-rss/network/ttrssnetworkfactory.cpp \ + src/services/tt-rss/ttrssfeed.cpp \ + src/services/tt-rss/ttrssserviceentrypoint.cpp \ + src/services/tt-rss/ttrssserviceroot.cpp \ + src/gui/settings/settingspanel.cpp \ + src/gui/settings/settingsgeneral.cpp \ + src/gui/settings/settingsdatabase.cpp \ + src/gui/settings/settingsshortcuts.cpp \ + src/gui/settings/settingsgui.cpp \ + src/gui/settings/settingslocalization.cpp \ + src/gui/settings/settingsbrowsermail.cpp \ + src/gui/settings/settingsfeedsmessages.cpp \ + src/gui/settings/settingsdownloads.cpp \ + src/miscellaneous/feedreader.cpp \ + src/services/standard/atomparser.cpp \ + src/services/standard/feedparser.cpp \ + src/services/standard/rdfparser.cpp \ + src/services/standard/rssparser.cpp \ + src/services/abstract/cacheforserviceroot.cpp \ + src/services/tt-rss/gui/formeditttrssaccount.cpp \ + src/gui/guiutilities.cpp \ + src/core/messagesmodelcache.cpp \ + src/core/messagesmodelsqllayer.cpp \ + src/gui/treeviewcolumnsmenu.cpp \ + src/services/abstract/labelsrootitem.cpp \ + src/services/abstract/label.cpp \ + src/miscellaneous/externaltool.cpp \ + src/services/inoreader/inoreaderentrypoint.cpp \ + src/services/inoreader/network/inoreadernetworkfactory.cpp \ + src/services/inoreader/inoreaderserviceroot.cpp \ + src/services/inoreader/gui/formeditinoreaderaccount.cpp \ + src/services/inoreader/inoreaderfeed.cpp + +OBJECTIVE_SOURCES += src/miscellaneous/disablewindowtabbing.mm + +FORMS += src/gui/toolbareditor.ui \ + src/network-web/downloaditem.ui \ + src/network-web/downloadmanager.ui \ + src/gui/dialogs/formabout.ui \ + src/gui/dialogs/formaddaccount.ui \ + src/gui/dialogs/formbackupdatabasesettings.ui \ + src/gui/dialogs/formdatabasecleanup.ui \ + src/gui/dialogs/formmain.ui \ + src/gui/dialogs/formrestoredatabasesettings.ui \ + src/gui/dialogs/formsettings.ui \ + src/gui/dialogs/formupdate.ui \ + src/services/abstract/gui/formfeeddetails.ui \ + src/services/owncloud/gui/formeditowncloudaccount.ui \ + src/services/standard/gui/formstandardcategorydetails.ui \ + src/services/standard/gui/formstandardimportexport.ui \ + src/gui/settings/settingsgeneral.ui \ + src/gui/settings/settingsdatabase.ui \ + src/gui/settings/settingsshortcuts.ui \ + src/gui/settings/settingsgui.ui \ + src/gui/settings/settingslocalization.ui \ + src/gui/settings/settingsbrowsermail.ui \ + src/gui/settings/settingsfeedsmessages.ui \ + src/gui/settings/settingsdownloads.ui \ + src/services/tt-rss/gui/formeditttrssaccount.ui \ + src/services/inoreader/gui/formeditinoreaderaccount.ui + +equals(USE_WEBENGINE, true) { + HEADERS += src/gui/locationlineedit.h \ + src/gui/webviewer.h \ + src/gui/webbrowser.h \ + src/gui/discoverfeedsbutton.h \ + src/network-web/googlesuggest.h \ + src/network-web/webpage.h \ + src/network-web/rssguardschemehandler.h + + SOURCES += src/gui/locationlineedit.cpp \ + src/gui/webviewer.cpp \ + src/gui/webbrowser.cpp \ + src/gui/discoverfeedsbutton.cpp \ + src/network-web/googlesuggest.cpp \ + src/network-web/webpage.cpp \ + src/network-web/rssguardschemehandler.cpp + + # Add AdBlock sources. + HEADERS += src/network-web/adblock/adblockaddsubscriptiondialog.h \ + src/network-web/adblock/adblockdialog.h \ + src/network-web/adblock/adblockicon.h \ + src/network-web/adblock/adblockmanager.h \ + src/network-web/adblock/adblockmatcher.h \ + src/network-web/adblock/adblockrule.h \ + src/network-web/adblock/adblocksearchtree.h \ + src/network-web/adblock/adblocksubscription.h \ + src/network-web/adblock/adblocktreewidget.h \ + src/network-web/adblock/adblockurlinterceptor.h \ + src/network-web/urlinterceptor.h \ + src/network-web/networkurlinterceptor.h \ + src/miscellaneous/simpleregexp.h \ + src/gui/treewidget.h + + SOURCES += src/network-web/adblock/adblockaddsubscriptiondialog.cpp \ + src/network-web/adblock/adblockdialog.cpp \ + src/network-web/adblock/adblockicon.cpp \ + src/network-web/adblock/adblockmanager.cpp \ + src/network-web/adblock/adblockmatcher.cpp \ + src/network-web/adblock/adblockrule.cpp \ + src/network-web/adblock/adblocksearchtree.cpp \ + src/network-web/adblock/adblocksubscription.cpp \ + src/network-web/adblock/adblocktreewidget.cpp \ + src/network-web/adblock/adblockurlinterceptor.cpp \ + src/network-web/networkurlinterceptor.cpp \ + src/miscellaneous/simpleregexp.cpp \ + src/gui/treewidget.cpp + + FORMS += src/network-web/adblock/adblockaddsubscriptiondialog.ui \ + src/network-web/adblock/adblockdialog.ui +} +else { + HEADERS += src/gui/messagepreviewer.h \ + src/gui/messagetextbrowser.h \ + src/gui/newspaperpreviewer.h + + SOURCES += src/gui/messagepreviewer.cpp \ + src/gui/messagetextbrowser.cpp \ + src/gui/newspaperpreviewer.cpp + + FORMS += src/gui/messagepreviewer.ui \ + src/gui/newspaperpreviewer.ui +} + +TRANSLATIONS += localization/qtbase_cs.ts \ + localization/qtbase_da.ts \ + localization/qtbase_de.ts \ + localization/qtbase_fr.ts \ + localization/qtbase_he.ts \ + localization/qtbase_it.ts \ + localization/qtbase_ja.ts \ + localization/qtbase_sv.ts \ + localization/rssguard_cs.ts \ + localization/rssguard_da.ts \ + localization/rssguard_de.ts \ + localization/rssguard_en_GB.ts \ + localization/rssguard_en.ts \ + localization/rssguard_es.ts \ + localization/rssguard_fr.ts \ + localization/rssguard_he.ts \ + localization/rssguard_id.ts \ + localization/rssguard_it.ts \ + localization/rssguard_ja.ts \ + localization/rssguard_lt.ts \ + localization/rssguard_nl.ts \ + localization/rssguard_pl.ts \ + localization/rssguard_pt.ts \ + localization/rssguard_sv.ts \ + localization/rssguard_zh.ts + +TRANSLATIONS_WO_QT += $$PWD/localization/rssguard_cs.ts \ + $$PWD/localization/rssguard_da.ts \ + $$PWD/localization/rssguard_de.ts \ + $$PWD/localization/rssguard_en_GB.ts \ + $$PWD/localization/rssguard_en.ts \ + $$PWD/localization/rssguard_es.ts \ + $$PWD/localization/rssguard_fr.ts \ + $$PWD/localization/rssguard_he.ts \ + $$PWD/localization/rssguard_id.ts \ + $$PWD/localization/rssguard_it.ts \ + $$PWD/localization/rssguard_ja.ts \ + $$PWD/localization/rssguard_lt.ts \ + $$PWD/localization/rssguard_nl.ts \ + $$PWD/localization/rssguard_pl.ts \ + $$PWD/localization/rssguard_pt.ts \ + $$PWD/localization/rssguard_sv.ts \ + $$PWD/localization/rssguard_zh.ts + +INCLUDEPATH += $$PWD/. \ + $$PWD/src \ + $$PWD/src/gui \ + $$PWD/src/gui/dialogs \ + $$PWD/src/dynamic-shortcuts + +TEXTS = resources/text/CHANGELOG \ + resources/text/COPYING_BSD \ + resources/text/COPYING_GNU_GPL \ + resources/text/COPYING_GNU_GPL_HTML + +# Make sure QM translations are generated. +lrelease.input = TRANSLATIONS +lrelease.output = $$OUT_PWD/translations/${QMAKE_FILE_BASE}.qm +lrelease.commands = $$LRELEASE_EXECUTABLE -compress ${QMAKE_FILE_IN} -qm $$OUT_PWD/translations/${QMAKE_FILE_BASE}.qm +lrelease.CONFIG += no_link target_predeps + +# Create new "make lupdate" target. +lupdate.target = lupdate +lupdate.commands = lupdate $$shell_path($$PWD/rssguard.pro) -ts $$shell_path($$TRANSLATIONS_WO_QT) + +QMAKE_EXTRA_TARGETS += lupdate +QMAKE_EXTRA_COMPILERS += lrelease + +# Create new "make 7zip" target and "make zip" target. +win32 { + seven_zip.target = 7zip + seven_zip.depends = install + seven_zip.commands = $$shell_path($$shell_quote($$PWD/resources/scripts/7za/7za.exe)) a -t7z $$TARGET-$$APP_VERSION-$$APP_REVISION-$${APP_WIN_ARCH}.7z $$shell_path($$PREFIX/*) + + zip.target = zip + zip.depends = install + zip.commands = $$shell_path($$shell_quote($$PWD/resources/scripts/7za/7za.exe)) a -tzip $$TARGET-$$APP_VERSION-$$APP_REVISION-$${APP_WIN_ARCH}.zip $$shell_path($$PREFIX/*) + + QMAKE_EXTRA_TARGETS += seven_zip zip +} + +unix:!mac { + seven_zip.target = 7zip + seven_zip.depends = install + seven_zip.commands = 7za a -t7z "$$TARGET-$$APP_VERSION-$$APP_REVISION-linux.7z" $$shell_quote($$shell_path($$PREFIX/*)) + + zip.target = zip + zip.depends = install + zip.commands = 7za a -tzip "$$TARGET-$$APP_VERSION-$$APP_REVISION-linux.zip" $$shell_quote($$shell_path($$PREFIX/*)) + + QMAKE_EXTRA_TARGETS += seven_zip zip +} + +mac { + seven_zip.target = 7zip + seven_zip.depends = install + seven_zip.commands = 7za a -t7z "$$TARGET-$$APP_VERSION-$$APP_REVISION-mac.7z" $$shell_quote($$shell_path($$PREFIX)) + + zip.target = zip + zip.depends = install + zip.commands = 7za a -tzip "$$TARGET-$$APP_VERSION-$$APP_REVISION-mac.zip" $$shell_quote($$shell_path($$PREFIX)) + + dmg.target = dmg + dmg.depends = install + dmg.commands = macdeployqt $$shell_quote($$shell_path($$PREFIX)) -dmg + + QMAKE_EXTRA_TARGETS += seven_zip zip dmg +} + +# Create NSIS installer target on Windows. +win32 { + nsis.target = nsis + nsis.depends = install + nsis.commands = \ + $$shell_path($$shell_quote($$PWD/resources/scripts/sed/sed.exe)) -e \"s|@APP_VERSION@|$$APP_VERSION|g; s|@APP_WIN_ARCH@|$$APP_WIN_ARCH|g; s|@APP_REVISION@|$$APP_REVISION|g; s|@APP_NAME@|$$APP_NAME|g; s|@APP_LOW_NAME@|$$APP_LOW_NAME|g; s|@EXE_NAME@|$${APP_LOW_NAME}.exe|g; s|@PWD@|$$replace(PWD, /, \\\\)|g; s|@OUT_PWD@|$$replace(OUT_PWD, /, \\\\)|g\" $$shell_path($$shell_quote($$PWD/resources/nsis/NSIS.definitions.nsh.in)) > $$shell_path($$shell_quote($$OUT_PWD/NSIS.definitions.nsh)) && \ + xcopy /Y $$shell_path($$shell_quote($$PWD/resources/nsis/NSIS.template.in)) $$shell_path($$shell_quote($$OUT_PWD/)) && \ + $$shell_path($$shell_quote($$PWD/resources/scripts/nsis/makensis.exe)) $$shell_path($$shell_quote($$OUT_PWD/NSIS.template.in)) + + QMAKE_EXTRA_TARGETS += nsis +} + +win32 { + windows_all.target = windows_all + windows_all.depends = seven_zip nsis + windows_all.commands = echo "windows_all done..." + + QMAKE_EXTRA_TARGETS += windows_all +} + +# Install all files on Windows. +win32 { + target.path = $$PREFIX + + qt_dlls_root.files = resources/binaries/windows/qt5-msvc2015/*.* + qt_dlls_root.path = $$quote($$PREFIX/) + + qt_dlls_plugins.files = resources/binaries/windows/qt5-msvc2015/* + qt_dlls_plugins.path = $$quote($$PREFIX/) + + misc_sql.files = resources/sql/*.sql + misc_sql.path = $$quote($$PREFIX/sql/) + + misc_icons.files = resources/graphics/misc + misc_icons.path = $$quote($$PREFIX/icons/) + + faenza.files = resources/graphics/Faenza + faenza.path = $$quote($$PREFIX/icons/) + + skins.files = resources/skins + skins.path = $$quote($$PREFIX/) + + feeds.files = resources/initial_feeds + feeds.path = $$quote($$PREFIX/) + + texts.files = $$TEXTS + texts.path = $$quote($$PREFIX/) + + ico.files = resources/graphics/$${TARGET}.ico + ico.path = $$quote($$PREFIX/) + + app_icon.files = resources/graphics/$${TARGET}.png + app_icon.path = $$quote($$PREFIX/) + + app_plain_icon.files = resources/graphics/$${TARGET}_plain.png + app_plain_icon.path = $$quote($$PREFIX/) + + translations.files = $$OUT_PWD/translations + translations.path = $$quote($$PREFIX/) + + INSTALLS += target misc_sql qt_dlls_root qt_dlls_plugins \ + misc_icons faenza skins \ + feeds texts ico app_icon app_plain_icon translations + + equals(USE_WEBENGINE, true) { + # Copy extra resource files for QtWebEngine. + qtwebengine_dlls.files = resources/binaries/windows/qt5-msvc2015-webengine/* + qtwebengine_dlls.path = $$quote($$PREFIX/) + + qtwebengine.files = resources/binaries/windows/qt5-msvc2015-webengine/*.* + qtwebengine.path = $$quote($$PREFIX/) + + INSTALLS += qtwebengine_dlls qtwebengine + } +} + +# Install all files on Linux. +unix:!mac { + target.path = $$PREFIX/bin + + # Install SQL initializers. + misc_sql.files = resources/sql/*.sql + misc_sql.path = $$quote($$PREFIX/share/$$TARGET/sql/) + + # Misc icons. + misc_icons.files = resources/graphics/misc + misc_icons.path = $$quote($$PREFIX/share/$$TARGET/icons/) + + # Initial feeds. + misc_feeds.files = resources/initial_feeds + misc_feeds.path = $$quote($$PREFIX/share/$$TARGET/) + + misc_icon.files = resources/graphics/$${TARGET}.png + misc_icon.path = $$quote($$PREFIX/share/pixmaps/) + + skins.files = resources/skins + skins.path = $$quote($$PREFIX/share/$$TARGET/) + + misc_plain_icon.files = resources/graphics/$${TARGET}_plain.png + misc_plain_icon.path = $$quote($$PREFIX/share/$$TARGET/icons/) + + misc_texts.files = $$TEXTS + misc_texts.path = $$quote($$PREFIX/share/$$TARGET/information/) + + desktop_file.files = resources/desktop/$${TARGET}.desktop + desktop_file.path = $$quote($$PREFIX/share/applications/) + + desktop_file_autostart.files = resources/desktop/$${TARGET}.desktop.autostart + desktop_file_autostart.path = $$quote($$PREFIX/share/$${TARGET}/autostart/) + + translations.files = $$OUT_PWD/translations + translations.path = $$quote($$PREFIX/share/$$TARGET/) + + INSTALLS += target misc_sql misc_icons misc_feeds \ + misc_icon misc_plain_icon skins misc_texts \ + desktop_file desktop_file_autostart translations +} + +mac { + IDENTIFIER = org.$${TARGET}.RSSGuard + CONFIG -= app_bundle + ICON = resources/macosx/$${TARGET}.icns + QMAKE_MAC_SDK = macosx10.12 + QMAKE_MACOSX_DEPLOYMENT_TARGET = 10.7 + LIBS += -framework AppKit + + target.path = $$quote($$PREFIX/Contents/MacOS/) + + # Install app icon. + icns_icon.files = resources/macosx/$${TARGET}.icns + icns_icon.path = $$quote($$PREFIX/Contents/Resources/) + + # Install Info.plist. + info_plist.files = resources/macosx/Info.plist.in + info_plist.path = $$quote($$PREFIX/Contents/) + + # Process the just installed Info.plist. + info_plist2.extra = @sed -e "s,@EXECUTABLE@,$$TARGET,g" -e "s,@SHORT_VERSION@,$$APP_VERSION,g" -e "s,@APP_NAME@,\"$$APP_NAME\",g" -e "s,@ICON@,$$basename(ICON),g" -e "s,@TYPEINFO@,"????",g" $$shell_quote($$PREFIX/Contents/Info.plist.in) > $$shell_quote($$PREFIX/Contents/Info.plist) && \ + rm -f $$shell_quote($$PREFIX/Contents/Info.plist.in) + info_plist2.path = $$quote($$PREFIX/Contents/) + + # Install PkgInfo + pkginfo.extra = @printf "APPL????" > $$shell_quote($$PREFIX/Contents/PkgInfo) + pkginfo.path = $$quote($$PREFIX/Contents/) + + # Install SQL initializers. + misc_sql.files = resources/sql + misc_sql.path = $$quote($$PREFIX/Contents/Resources/) + + # Misc icons. + misc_icons.files = resources/graphics/misc + misc_icons.path = $$quote($$PREFIX/Contents/Resources/icons/) + + faenza.files = resources/graphics/Faenza + faenza.path = $$quote($$PREFIX/Contents/Resources/icons/) + + # Initial feeds. + misc_feeds.files = resources/initial_feeds + misc_feeds.path = $$quote($$PREFIX/Contents/Resources/) + + skins.files = resources/skins + skins.path = $$quote($$PREFIX/Contents/Resources) + + misc_icon.files = resources/graphics/$${TARGET}.png + misc_icon.path = $$quote($$PREFIX/Contents/Resources/icons) + + misc_plain_icon.files = resources/graphics/$${TARGET}_plain.png + misc_plain_icon.path = $$quote($$PREFIX/Contents/Resources/icons/) + + misc_texts.files = $$TEXTS + misc_texts.path = $$quote($$PREFIX/Contents/Resources/information/) + + translations.files = $$OUT_PWD/translations + translations.path = $$quote($$PREFIX/Contents/Resources/) + + INSTALLS += target icns_icon info_plist info_plist2 pkginfo \ + misc_sql misc_icons faenza misc_feeds skins \ + misc_icon misc_plain_icon misc_texts translations + +} + +win32:CONFIG(release, debug|release): LIBS += -L$$PWD/../build-qtnetworkauth-Desktop-Debug/lib/release/ -lQt5NetworkAuth +else:win32:CONFIG(debug, debug|release): LIBS += -L$$PWD/../build-qtnetworkauth-Desktop-Debug/lib/debug/ -lQt5NetworkAuth +else:unix: LIBS += -L$$PWD/../build-qtnetworkauth-Desktop-Debug/lib/ -lQt5NetworkAuth + +INCLUDEPATH += $$PWD/../build-qtnetworkauth-Desktop-Debug/include +DEPENDPATH += $$PWD/../build-qtnetworkauth-Desktop-Debug/include diff --git a/src/miscellaneous/databasequeries.cpp b/src/miscellaneous/databasequeries.cpp index 47857de76..aad602678 100755 --- a/src/miscellaneous/databasequeries.cpp +++ b/src/miscellaneous/databasequeries.cpp @@ -22,6 +22,7 @@ #include "miscellaneous/iconfactory.h" #include "miscellaneous/textfactory.h" #include "services/abstract/category.h" +#include "services/inoreader/inoreaderfeed.h" #include "services/inoreader/inoreaderserviceroot.h" #include "services/inoreader/network/inoreadernetworkfactory.h" #include "services/owncloud/definitions.h" @@ -1482,6 +1483,37 @@ Assignment DatabaseQueries::getCategories(QSqlDatabase db, int account_id, bool* return categories; } +Assignment DatabaseQueries::getInoreaderFeeds(QSqlDatabase db, int account_id, bool* ok) { + Assignment feeds; + QSqlQuery q(db); + + q.setForwardOnly(true); + q.prepare(QSL("SELECT * FROM Feeds WHERE account_id = :account_id;")); + q.bindValue(QSL(":account_id"), account_id); + + if (!q.exec()) { + qFatal("Inoreader: Query for obtaining feeds failed. Error message: '%s'.", qPrintable(q.lastError().text())); + + if (ok != nullptr) { + *ok = false; + } + } + + while (q.next()) { + AssignmentItem pair; + + pair.first = q.value(FDS_DB_CATEGORY_INDEX).toInt(); + pair.second = new InoreaderFeed(q.record()); + feeds << pair; + } + + if (ok != nullptr) { + *ok = true; + } + + return feeds; +} + QList DatabaseQueries::getInoreaderAccounts(QSqlDatabase db, bool* ok) { QSqlQuery query(db); diff --git a/src/miscellaneous/databasequeries.h b/src/miscellaneous/databasequeries.h index b05eaa11b..d0174de00 100755 --- a/src/miscellaneous/databasequeries.h +++ b/src/miscellaneous/databasequeries.h @@ -79,6 +79,7 @@ class DatabaseQueries { static Assignment getCategories(QSqlDatabase db, int account_id, bool* ok = nullptr); // Inoreader account. + static Assignment getInoreaderFeeds(QSqlDatabase db, int account_id, bool* ok = nullptr); static QList getInoreaderAccounts(QSqlDatabase db, bool* ok = nullptr); static bool overwriteInoreaderAccount(QSqlDatabase db, const QString& username, const QString& access_token, const QString& refresh_token, int batch_size, int account_id); diff --git a/src/services/inoreader/inoreaderfeed.cpp b/src/services/inoreader/inoreaderfeed.cpp new file mode 100644 index 000000000..cf2b8dcc9 --- /dev/null +++ b/src/services/inoreader/inoreaderfeed.cpp @@ -0,0 +1,43 @@ +// This file is part of RSS Guard. + +// +// Copyright (C) 2011-2017 by Martin Rotter +// +// RSS Guard is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// RSS Guard is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with RSS Guard. If not, see . + +#include "services/inoreader/inoreaderfeed.h" + +#include "miscellaneous/application.h" +#include "miscellaneous/iconfactory.h" +#include "services/inoreader/inoreaderserviceroot.h" + +InoreaderFeed::InoreaderFeed(RootItem* parent) : Feed(parent) {} + +InoreaderFeed::InoreaderFeed(const QSqlRecord& record) : InoreaderFeed(nullptr) { + setTitle(record.value(FDS_DB_TITLE_INDEX).toString()); + setId(record.value(FDS_DB_ID_INDEX).toInt()); + setCustomId(record.value(FDS_DB_CUSTOM_ID_INDEX).toString()); + setIcon(qApp->icons()->fromByteArray(record.value(FDS_DB_ICON_INDEX).toByteArray())); + setAutoUpdateType(static_cast(record.value(FDS_DB_UPDATE_TYPE_INDEX).toInt())); + setAutoUpdateInitialInterval(record.value(FDS_DB_UPDATE_INTERVAL_INDEX).toInt()); + qDebug("Custom ID of Inoreader feed when loading from DB is '%s'.", qPrintable(customId())); +} + +InoreaderServiceRoot* InoreaderFeed::serviceRoot() const { + return qobject_cast(getParentServiceRoot()); +} + +QList InoreaderFeed::obtainNewMessages(bool* error_during_obtaining) { + return QList(); +} diff --git a/src/services/inoreader/inoreaderfeed.h b/src/services/inoreader/inoreaderfeed.h new file mode 100644 index 000000000..18db614bb --- /dev/null +++ b/src/services/inoreader/inoreaderfeed.h @@ -0,0 +1,37 @@ +// This file is part of RSS Guard. + +// +// Copyright (C) 2011-2017 by Martin Rotter +// +// RSS Guard is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// RSS Guard is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with RSS Guard. If not, see . + +#ifndef INOREADERFEED_H +#define INOREADERFEED_H + +#include "services/abstract/feed.h" + +class InoreaderServiceRoot; + +class InoreaderFeed : public Feed { + public: + explicit InoreaderFeed(RootItem* parent = nullptr); + explicit InoreaderFeed(const QSqlRecord& record); + + InoreaderServiceRoot* serviceRoot() const; + + private: + QList obtainNewMessages(bool* error_during_obtaining); +}; + +#endif // INOREADERFEED_H diff --git a/src/services/inoreader/inoreaderserviceroot.cpp b/src/services/inoreader/inoreaderserviceroot.cpp index 3fc7922c6..4ce83995f 100755 --- a/src/services/inoreader/inoreaderserviceroot.cpp +++ b/src/services/inoreader/inoreaderserviceroot.cpp @@ -44,6 +44,20 @@ void InoreaderServiceRoot::updateTitle() { setTitle(m_network->userName() + QSL(" (Inoreader)")); } +void InoreaderServiceRoot::loadFromDatabase() { + QSqlDatabase database = qApp->database()->connection(metaObject()->className(), DatabaseFactory::FromSettings); + Assignment categories = DatabaseQueries::getCategories(database, accountId()); + Assignment feeds = DatabaseQueries::getInoreaderFeeds(database, accountId()); + + // All data are now obtained, lets create the hierarchy. + assembleCategories(categories); + assembleFeeds(feeds); + + // As the last item, add recycle bin, which is needed. + appendChild(recycleBin()); + updateCounts(true); +} + void InoreaderServiceRoot::saveAccountDataToDatabase() { QSqlDatabase database = qApp->database()->connection(metaObject()->className(), DatabaseFactory::FromSettings); @@ -93,7 +107,8 @@ bool InoreaderServiceRoot::supportsCategoryAdding() const { void InoreaderServiceRoot::start(bool freshly_activated) { Q_UNUSED(freshly_activated) - //loadFromDatabase(); + loadFromDatabase(); + //loadCacheFromFile(accountId()); m_network->logInIfNeeded(); diff --git a/src/services/inoreader/inoreaderserviceroot.h b/src/services/inoreader/inoreaderserviceroot.h index 270511f49..7b56ca9f9 100755 --- a/src/services/inoreader/inoreaderserviceroot.h +++ b/src/services/inoreader/inoreaderserviceroot.h @@ -51,7 +51,8 @@ class InoreaderServiceRoot : public ServiceRoot { void addNewCategory(); void updateTitle(); - protected: + private: + void loadFromDatabase(); QList serviceMenu(); private: diff --git a/src/services/inoreader/network/inoreadernetworkfactory.cpp b/src/services/inoreader/network/inoreadernetworkfactory.cpp index 15fdb4553..2d27690bb 100755 --- a/src/services/inoreader/network/inoreadernetworkfactory.cpp +++ b/src/services/inoreader/network/inoreadernetworkfactory.cpp @@ -179,8 +179,7 @@ RootItem* InoreaderNetworkFactory::feedsCategories(bool obtain_icons) { if (NetworkFactory::performNetworkOperation(icon_url, DOWNLOAD_TIMEOUT, QByteArray(), QString(), icon_data, - QNetworkAccessManager::GetOperation).first == - QNetworkReply::NoError) { + QNetworkAccessManager::GetOperation).first == QNetworkReply::NoError) { // Icon downloaded, set it up. QPixmap icon_pixmap;