X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=CMakeLists.txt;h=e4f5d617b985b9eb83ba9027925868cf232eeccd;hp=fb7041459f15cce88a95f9e66e1398d105c8b77c;hb=46bba99808aad823adc53744e6d93f5af9bf729d;hpb=b5c64cce8e7813090809a3e4de8f88e148f84392 diff --git a/CMakeLists.txt b/CMakeLists.txt index fb704145..e4f5d617 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -150,35 +150,32 @@ endif() ##################################################################### set(QT_MIN_VERSION "5.5.0") -add_definitions(-DHAVE_QT5) -find_package(Qt5Core ${QT_MIN_VERSION} QUIET) -set_package_properties(Qt5Core PROPERTIES TYPE REQUIRED +# Required Qt components +set(qt_components Core Network) +if (BUILD_GUI) + list(APPEND qt_components Gui Widgets) +endif() +if (BUILD_CORE) + list(APPEND qt_components Script Sql) +endif() + +find_package(Qt5 ${QT_MIN_VERSION} REQUIRED COMPONENTS ${qt_components}) +set_package_properties(Qt5 PROPERTIES TYPE REQUIRED URL "https://www.qt.io/" - DESCRIPTION "contains core functionality for Qt" + DESCRIPTION "the Qt libraries" ) +message(STATUS "Found Qt ${Qt5Core_VERSION}") -# find_package without REQUIRED won't check for the version properly; also, older Qt5 versions -# used Qt5Core_VERSION_STRING... let's just make sure here that we bail out here if our Qt5 is not new enough. -if (NOT Qt5Core_VERSION OR Qt5Core_VERSION VERSION_LESS ${QT_MIN_VERSION}) - message(FATAL_ERROR "Could NOT find Qt5 >= version ${QT_MIN_VERSION}!") -endif() +# Optional Qt components -find_package(Qt5Network QUIET) -set_package_properties(Qt5Network PROPERTIES TYPE REQUIRED - DESCRIPTION "the network module for Qt5" +find_package(Qt5LinguistTools QUIET) +set_package_properties(Qt5LinguistTools PROPERTIES TYPE RECOMMENDED + DESCRIPTION "contains tools for handling translation files" + PURPOSE "Required for having translations" ) if (BUILD_GUI) - find_package(Qt5Gui QUIET) - set_package_properties(Qt5Gui PROPERTIES TYPE REQUIRED - DESCRIPTION "the GUI module for Qt5" - ) - find_package(Qt5Widgets QUIET) - set_package_properties(Qt5Widgets PROPERTIES TYPE REQUIRED - DESCRIPTION "the widgets module for Qt5" - ) - if (NOT WIN32) find_package(Qt5DBus QUIET) set_package_properties(Qt5DBus PROPERTIES TYPE RECOMMENDED @@ -209,37 +206,15 @@ if (BUILD_GUI) DESCRIPTION "a cross-platform notification framework" PURPOSE "Enable support for the snorenotify framework" ) - if(LibsnoreQt5_FOUND) - find_package(LibsnoreSettingsQt5) - set_package_properties(LibsnoreSettingsQt5 PROPERTIES TYPE REQUIRED + if (LibsnoreQt5_FOUND) + find_package(LibsnoreSettingsQt5 QUIET) + set_package_properties(LibsnoreSettingsQt5 PROPERTIES TYPE OPTIONAL URL "https://projects.kde.org/projects/playground/libs/snorenotify" DESCRIPTION "a cross-platform notification framework" PURPOSE "Enable support for the snorenotify framework" ) endif() - if (WITH_WEBKIT) - find_package(Qt5WebKit QUIET) - set_package_properties(Qt5WebKit PROPERTIES TYPE RECOMMENDED - URL "https://www.qt.io/" - DESCRIPTION "a WebKit implementation for Qt" - PURPOSE "Needed for displaying previews for URLs in chat" - ) - if (Qt5WebKit_FOUND) - find_package(Qt5WebKitWidgets QUIET) - set_package_properties(Qt5WebKitWidgets PROPERTIES TYPE RECOMMENDED - URL "https://www.qt.io/" - DESCRIPTION "widgets for Qt's WebKit implementation" - PURPOSE "Needed for displaying previews for URLs in chat" - ) - endif() - endif() - - if (WITH_WEBKIT AND Qt5WebKitWidgets_FOUND) - set(HAVE_WEBKIT true) - endif() - add_feature_info("WITH_WEBKIT, QtWebKit and QtWebKitWidgets modules" HAVE_WEBKIT "Support showing previews for URLs in chat (legacy)") - if (WITH_WEBENGINE) find_package(Qt5WebEngine QUIET) set_package_properties(Qt5WebEngine PROPERTIES TYPE RECOMMENDED @@ -262,18 +237,43 @@ if (BUILD_GUI) endif() add_feature_info("WITH_WEBENGINE, QtWebEngine and QtWebEngineWidgets modules" HAVE_WEBENGINE "Support showing previews for URLs in chat") + if (NOT HAVE_WEBENGINE) + if (WITH_WEBKIT) + find_package(Qt5WebKit QUIET) + set_package_properties(Qt5WebKit PROPERTIES TYPE OPTIONAL + URL "https://www.qt.io/" + DESCRIPTION "a WebKit implementation for Qt" + PURPOSE "Needed for displaying previews for URLs in chat" + ) + if (Qt5WebKit_FOUND) + find_package(Qt5WebKitWidgets QUIET) + set_package_properties(Qt5WebKitWidgets PROPERTIES TYPE OPTIONAL + URL "https://www.qt.io/" + DESCRIPTION "widgets for Qt's WebKit implementation" + PURPOSE "Needed for displaying previews for URLs in chat" + ) + endif() + endif() + + if (WITH_WEBKIT AND Qt5WebKitWidgets_FOUND) + set(HAVE_WEBKIT true) + endif() + add_feature_info("WITH_WEBKIT, QtWebKit and QtWebKitWidgets modules" HAVE_WEBKIT "Support showing previews for URLs in chat (legacy)") + endif() + # KDE Frameworks ################ + # extra-cmake-modules if (WITH_KDE) set(ecm_find_type "REQUIRED") + find_package(ECM NO_MODULE REQUIRED) else() # Even with KDE integration disabled, we optionally use tier1 frameworks if we find them set(ecm_find_type "RECOMMENDED") + find_package(ECM NO_MODULE QUIET) endif() - # extra-cmake-modules - find_package(ECM NO_MODULE QUIET) set_package_properties(ECM PROPERTIES TYPE ${ecm_find_type} URL "https://projects.kde.org/projects/kdesupport/extra-cmake-modules" DESCRIPTION "extra modules for CMake, maintained by the KDE project" @@ -283,49 +283,43 @@ if (BUILD_GUI) if (ECM_FOUND) list(APPEND CMAKE_MODULE_PATH ${ECM_MODULE_PATH}) if (WITH_KDE) - find_package(KF5 COMPONENTS ConfigWidgets CoreAddons Notifications NotifyConfig Sonnet TextWidgets WidgetsAddons XmlGui QUIET) + find_package(KF5 REQUIRED COMPONENTS ConfigWidgets CoreAddons Notifications NotifyConfig Sonnet TextWidgets WidgetsAddons XmlGui) set_package_properties(KF5 PROPERTIES TYPE REQUIRED URL "http://www.kde.org" DESCRIPTION "KDE Frameworks" PURPOSE "Required for integration into the Plasma desktop" ) - else() - find_package(KF5Sonnet QUIET) - set_package_properties(KF5Sonnet PROPERTIES TYPE RECOMMENDED - URL "http://api.kde.org/frameworks-api/frameworks5-apidocs/sonnet/html" - DESCRIPTION "framework for providing spell-checking capabilities" - PURPOSE "Enables spell-checking support in input widgets" - ) + message(STATUS "Found KDE Frameworks ${KF5_VERSION}") endif() - endif() + # Optional KF5 tier1 components + find_package(KF5Sonnet QUIET) + set_package_properties(KF5Sonnet PROPERTIES TYPE RECOMMENDED + URL "http://api.kde.org/frameworks-api/frameworks5-apidocs/sonnet/html" + DESCRIPTION "framework for providing spell-checking capabilities" + PURPOSE "Enables spell-checking support in input widgets" + ) + endif() endif() if (BUILD_CORE) - find_package(Qt5Script QUIET) - set_package_properties(Qt5Script PROPERTIES TYPE REQUIRED - DESCRIPTION "provides scripting support for Qt5" - ) - find_package(Qt5Sql QUIET) - set_package_properties(Qt5Sql PROPERTIES TYPE REQUIRED - DESCRIPTION "the database support module for Qt5" - ) - - find_package(Qca-qt5 2.0) + find_package(Qca-qt5 2.0 QUIET) set_package_properties(Qca-qt5 PROPERTIES TYPE RECOMMENDED URL "https://projects.kde.org/projects/kdesupport/qca" DESCRIPTION "Qt Cryptographic Architecture" PURPOSE "Required for encryption support" ) + if (WITH_LDAP) + find_package(Ldap QUIET) + set_package_properties(Ldap PROPERTIES TYPE OPTIONAL + URL "http://www.openldap.org/" + DESCRIPTION "LDAP (Lightweight Directory Access Protocol) libraries" + PURPOSE "Enables core user authentication via LDAP" + ) + endif() endif() -find_package(Qt5LinguistTools QUIET) -set_package_properties(Qt5LinguistTools PROPERTIES TYPE RECOMMENDED - DESCRIPTION "contains tools for handling translation files" - PURPOSE "Required for having translations" -) - # Non-Qt-based packages find_package(ZLIB REQUIRED) @@ -364,12 +358,6 @@ add_feature_info("SSL support in Qt" HAVE_SSL "Use secure network connections") # Additional compile settings ##################################################################### -# This sets -fPIC and friends if required by the installed Qt5 library -if (Qt5_POSITION_INDEPENDENT_CODE) - set(CMAKE_POSITION_INDEPENDENT_CODE ON) - set(CMAKE_REQUIRED_FLAGS "-DQT_NO_VERSION_TAGGING") -endif() - # Needed to compile with mingw without kde if (MINGW AND NOT WITH_KDE) add_definitions(-D_WIN32_WINNT=0x0500) @@ -378,24 +366,6 @@ if (MINGW AND NOT WITH_KDE) add_definitions(-U__STRICT_ANSI__) endif() -# Sanitize compiler flags - old versions of KDE set -ansi, which breaks -std=c++11 -if (CMAKE_COMPILER_IS_GNUCXX) - string(REPLACE "-ansi" "" CMAKE_CXX_FLAGS ${CMAKE_CXX_FLAGS}) -endif() - -# Setup LDAP Authentication support. -##################################################################### -if (WITH_LDAP) - find_package(Ldap) - if (LDAP_FOUND) - message(STATUS "Enabling LDAP authentication support") - else() - message(STATUS "Disabling LDAP authentication support") - endif() -else() - message(STATUS "Not enabling LDAP authentication support") -endif() - # Setup support for KDE Frameworks ##################################################################### @@ -448,7 +418,6 @@ if (WIN32) set(CMAKE_EXE_LINKER_FLAGS_DEBUG "/debug /INCREMENTAL:YES /NODEFAULTLIB:libcmt") set(CMAKE_EXE_LINKER_FLAGS_DEBUGFULL "${CMAKE_EXE_LINKER_FLAGS_DEBUG}") link_libraries(Version dwmapi shlwapi) - set(QT_QTMAIN_LIBRARY Qt5::WinMain) endif() endif()