X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=CMakeLists.txt;h=721e339cfbb9c15ac31e8bad4f264340afb29e48;hp=f8c0a5086018e476c0d4cd9e1f2649eae6261d51;hb=893f0c21b72d7e4aedde092887073c590155b6d9;hpb=931e5280abc6738f94ac052af2a7e31e82487cf1 diff --git a/CMakeLists.txt b/CMakeLists.txt index f8c0a508..721e339c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -6,25 +6,49 @@ # General setup ##################################################################### -project(QuasselIRC) - # Versions set(QUASSEL_MAJOR 0) set(QUASSEL_MINOR 13) set(QUASSEL_PATCH 0) -set(QUASSEL_VERSION_STRING "0.13-pre") +set(QUASSEL_VERSION_STRING "0.13-rc1") + +# Build type +if (CMAKE_CONFIGURATION_TYPES) + set(CMAKE_CONFIGURATION_TYPES Release RelWithDebInfo Debug Debugfull Profile) + set(CMAKE_CONFIGURATION_TYPES "${CMAKE_CONFIGURATION_TYPES}" CACHE STRING "These are the configuration types we support" FORCE) +endif() + +if(NOT CMAKE_BUILD_TYPE) + set(CMAKE_BUILD_TYPE RelWithDebInfo CACHE STRING "Choose the type of build, options are: Release RelWithDebInfo Debug Debugfull Profile None" FORCE) +endif() -# We want to know CMake's version for debug reasons +# Output CMake and Quassel versions as well as build type for debug reasons +message(STATUS "Building Quassel ${QUASSEL_VERSION_STRING}...") message(STATUS "Using CMake ${CMAKE_VERSION}") +message(STATUS "CMake build type: ${CMAKE_BUILD_TYPE}") + +# Support ccache if found +# This should happen before calling project(), so compiler settings are validated. +option(USE_CCACHE "Enable support for ccache if available" ON) +if (USE_CCACHE) + message(STATUS "Checking for ccache") + find_program(CCACHE_PROGRAM ccache) + if (CCACHE_PROGRAM) + set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE "${CCACHE_PROGRAM}") + message(STATUS "Checking for ccache - enabled") + else() + message(STATUS "Checking for ccache - not found") + endif() +endif() -# Tell CMake about or own modules -set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake) +# Set up project +project(Quassel C CXX) # General conveniences set(CMAKE_AUTOMOC ON) set(CMAKE_INCLUDE_CURRENT_DIR ON) -# Include various CMake modules... +# Include various CMake modules include(CMakePushCheckState) include(CheckFunctionExists) include(CheckIncludeFile) @@ -32,7 +56,8 @@ include(CheckCXXSourceCompiles) include(CMakeDependentOption) include(FeatureSummary) -# ... and our own stuff +# Tell CMake about or own modules +set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake) include(QuasselCompileSettings) include(QuasselMacros) @@ -40,7 +65,7 @@ include(QuasselMacros) # Options and variables that can be set on the command line ##################################################################### -# First, choose a Qt version. We support USE_QT5 and USE_QT4; if neither is set, Qt5 will be used +# Choose a Qt version. We support USE_QT5 and USE_QT4; if neither is set, Qt5 will be used option(USE_QT5 "Enable support for Qt5" OFF) if (USE_QT5) # takes precedence set(USE_QT4 OFF) @@ -70,23 +95,19 @@ else() add_feature_info(WITH_KDE WITH_KDE "Integrate with the KDE Frameworks runtime environment") endif() -cmake_dependent_option(WITH_BREEZE "Install Breeze icon theme (usually shipped with KDE)" ON "NOT WITH_KDE" OFF) -cmake_dependent_option(WITH_BREEZE_DARK "Install Dark Breeze icon theme (usually shipped with KDE)" OFF "NOT WITH_KDE" OFF) -cmake_dependent_option(WITH_OXYGEN "Install Oxygen icon theme (usually shipped with KDE)" OFF "NOT WITH_KDE" OFF) -if (NOT WITH_KDE) - add_feature_info(WITH_BREEZE WITH_BREEZE "Install Breeze icon theme") - add_feature_info(WITH_BREEZE_DARK WITH_BREEZE_DARK "Install Dark Breeze icon theme") - add_feature_info(WITH_OXYGEN WITH_OXYGEN "Install Oxygen icon theme") -endif() +# Icon theme support. By default, install the Breeze icon theme (may be disabled if a system installation is present) +option(WITH_BUNDLED_ICONS "Install required icons from the Breeze icon theme" ON) +add_feature_info(WITH_BUNDLED_ICONS WITH_BUNDLED_ICONS "Install required icons from the Breeze icon theme") -if (WITH_OXYGEN) - add_definitions(-DWITH_OXYGEN) -endif() -if (WITH_BREEZE) - add_definitions(-DWITH_BREEZE) +# For Qt4, always support Oxygen +cmake_dependent_option(WITH_OXYGEN_ICONS "Support the Oxygen icon theme (KDE4)" OFF "USE_QT5" ON) +add_feature_info(WITH_OXYGEN_ICONS WITH_OXYGEN_ICONS "Support the Oxygen icon theme (KDE4)" OFF) + +if (WITH_BUNDLED_ICONS) + add_definitions(-DWITH_BUNDLED_ICONS) endif() -if (WITH_BREEZE_DARK) - add_definitions(-DWITH_BREEZE_DARK) +if (WITH_OXYGEN_ICONS) + add_definitions(-DWITH_OXYGEN_ICONS) endif() # For this, the feature info is added after we know if QtWebkit is installed @@ -133,9 +154,10 @@ if (LINK_EXTRA) endif() -# LDAP Authentication (and other authentication backends). +# List of authenticators and the cmake flags to build them +# (currently that's just LDAP, but more can be added here). #################################################################### -option(WITH_LDAP "Enable LDAP authentication support if present on system" ON) +option(WITH_LDAP "Enable LDAP authentication support if present on system" ON) # Setup CMake ##################################################################### @@ -157,6 +179,11 @@ if (POLICY CMP0063) cmake_policy(SET CMP0063 NEW) endif() +# Don't automoc generated files +if (POLICY CMP0071) + cmake_policy(SET CMP0071 OLD) +endif() + # Simplify later checks ##################################################################### @@ -185,7 +212,7 @@ if (USE_QT5) find_package(Qt5Core ${QT_MIN_VERSION} QUIET) set_package_properties(Qt5Core PROPERTIES TYPE REQUIRED - URL "http://qt.digia.com" + URL "https://www.qt.io/" DESCRIPTION "contains core functionality for Qt" ) # find_package without REQUIRED won't check for the version properly; also, older Qt5 versions @@ -212,7 +239,7 @@ if (USE_QT5) if (NOT WIN32) find_package(Qt5DBus QUIET) set_package_properties(Qt5DBus PROPERTIES TYPE RECOMMENDED - URL "http://qt.digia.com" + URL "https://www.qt.io/" DESCRIPTION "D-Bus support for Qt5" PURPOSE "Needed for supporting D-Bus-based notifications and tray icon, used by most modern desktop environments" ) @@ -228,7 +255,7 @@ if (USE_QT5) find_package(Qt5Multimedia QUIET) set_package_properties(Qt5Multimedia PROPERTIES TYPE RECOMMENDED - URL "http://qt.digia.com" + URL "https://www.qt.io/" DESCRIPTION "Multimedia support for Qt5" PURPOSE "Required for audio notifications" ) @@ -261,14 +288,14 @@ if (USE_QT5) if (WITH_WEBKIT) find_package(Qt5WebKit QUIET) set_package_properties(Qt5WebKit PROPERTIES TYPE RECOMMENDED - URL "http://qt.digia.com" + 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 "http://qt.digia.com" + URL "https://www.qt.io/" DESCRIPTION "widgets for Qt's WebKit implementation" PURPOSE "Needed for displaying previews for URLs in chat" ) @@ -283,14 +310,14 @@ if (USE_QT5) if (WITH_WEBENGINE) find_package(Qt5WebEngine QUIET) set_package_properties(Qt5WebEngine PROPERTIES TYPE RECOMMENDED - URL "http://qt.digia.com" + URL "https://www.qt.io/" DESCRIPTION "a WebEngine implementation for Qt" PURPOSE "Needed for displaying previews for URLs in chat" ) if (Qt5WebEngine_FOUND) find_package(Qt5WebEngineWidgets QUIET) set_package_properties(Qt5WebEngineWidgets PROPERTIES TYPE RECOMMENDED - URL "http://qt.digia.com" + URL "https://www.qt.io/" DESCRIPTION "widgets for Qt's WebEngine implementation" PURPOSE "Needed for displaying previews for URLs in chat" ) @@ -323,7 +350,7 @@ if (USE_QT5) if (ECM_FOUND) list(APPEND CMAKE_MODULE_PATH ${ECM_MODULE_PATH}) if (WITH_KDE) - find_package(KF5 COMPONENTS ConfigWidgets CoreAddons Notifications NotifyConfig TextWidgets WidgetsAddons XmlGui QUIET) + find_package(KF5 COMPONENTS ConfigWidgets CoreAddons Notifications NotifyConfig Sonnet TextWidgets WidgetsAddons XmlGui QUIET REQUIRED) set_package_properties(KF5 PROPERTIES TYPE REQUIRED URL "http://www.kde.org" DESCRIPTION "KDE Frameworks" @@ -520,20 +547,18 @@ endif() # Setup LDAP Authentication support. ##################################################################### -if(WITH_LDAP) - find_package(Ldap) - if(LDAP_FOUND) - message(STATUS "Enabling LDAP authentication support") - set(HAVE_LDAP true) - if(HAVE_LDAP) - add_definitions(-DHAVE_LDAP) - endif(HAVE_LDAP) - else(LDAP_FOUND) - message(STATUS "Disabling LDAP authentication support") - endif(LDAP_FOUND) -else(WITH_LDAP) - message(STATUS "Not enabling LDAP authentication support") -endif(WITH_LDAP) +if (WITH_LDAP) + find_package(Ldap) + if (LDAP_FOUND) + message(STATUS "Enabling LDAP authentication support") + set(HAVE_LDAP true) + add_definitions(-DHAVE_LDAP) + else() + message(STATUS "Disabling LDAP authentication support") + endif() +else() + message(STATUS "Not enabling LDAP authentication support") +endif() # Setup KDE / KDE Frameworks ##################################################################### @@ -546,7 +571,7 @@ if (KDE4_FOUND) set(EMBED_DATA OFF) # Better have the compile flags global, even for the core, to avoid problems with linking the mono client - add_definitions(-DHAVE_KDE -DHAVE_KDE4 ${KDE4_DEFINITIONS}) + add_definitions(-DHAVE_KDE -DHAVE_KDE4 ${KDE4_DEFINITIONS} ${KDE4_ENABLE_EXCEPTIONS}) set(WITH_KDE4 TRUE) endif() @@ -558,6 +583,7 @@ if (USE_QT5 AND WITH_KDE) include(KDECompilerSettings) include(KDECMakeSettings) + kde_enable_exceptions() add_definitions(-DHAVE_KDE -DHAVE_KF5) set(WITH_KF5 TRUE) endif() @@ -651,7 +677,7 @@ git_describe(GIT_DESCRIBE --long) # If in a Git repo we can get the commit-date from a git command if (GIT_HEAD) execute_process( - COMMAND git show -s --format=%ct + COMMAND git -c log.showsignature=false show -s --format=%ct WORKING_DIRECTORY ${CMAKE_SOURCE_DIR} OUTPUT_VARIABLE GIT_COMMIT_DATE OUTPUT_STRIP_TRAILING_WHITESPACE