X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=CMakeLists.txt;h=5668fcf0d021cac979b847b764acfc8834a137d4;hp=8293af05977c62143d2450da3a0b08e92f4f6671;hb=09e964ea3cd4995374dd7adb33256f3cefd47032;hpb=a27d49cabc3e0fc2831fb65d786d37601c43fed9 diff --git a/CMakeLists.txt b/CMakeLists.txt index 8293af05..5668fcf0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -14,8 +14,9 @@ set(QUASSEL_MINOR 13) set(QUASSEL_PATCH 0) set(QUASSEL_VERSION_STRING "0.13-pre") -# We want to know CMake's version for debug reasons +# Output CMake version and build type for debug reasons message(STATUS "Using CMake ${CMAKE_VERSION}") +message(STATUS "CMake build type: ${CMAKE_BUILD_TYPE}") # Tell CMake about or own modules set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake) @@ -40,13 +41,13 @@ include(QuasselMacros) # Options and variables that can be set on the command line ##################################################################### -# First, choose a Qt version. We support USE_QT4 and USE_QT5; if neither is set, prefer Qt4 for now -option(USE_QT5 "Enable support for Qt5 (disables KDE integration)" OFF) -if (USE_QT4) # takes precedence - set(USE_QT5 OFF) +# First, 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) else() - if (NOT USE_QT5) - set(USE_QT4 ON) + if (NOT USE_QT4) + set(USE_QT5 ON) endif() endif() @@ -70,9 +71,19 @@ else() add_feature_info(WITH_KDE WITH_KDE "Integrate with the KDE Frameworks runtime environment") endif() -cmake_dependent_option(WITH_OXYGEN "Install Oxygen icon set (usually shipped with KDE)" ON "NOT WITH_KDE" OFF) -if (NOT WITH_KDE) - add_feature_info(WITH_OXYGEN WITH_OXYGEN "Install Oxygen icon set") +# 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") + +# 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_OXYGEN_ICONS) + add_definitions(-DWITH_OXYGEN_ICONS) endif() # For this, the feature info is added after we know if QtWebkit is installed @@ -87,6 +98,9 @@ if (APPLE) option(WITH_NOTIFICATION_CENTER "OS X Notification Center support" ON) add_feature_info(WITH_NOTIFICATION_CENTER WITH_NOTIFICATION_CENTER "Use the OS X Notification Center") endif() + find_library(CARBON_LIBRARY Carbon) + mark_as_advanced(CARBON_LIBRARY) + link_libraries(${CARBON_LIBRARY}) endif() # Always embed on Windows, OSX or for a static build; never embed when enabling KDE integration @@ -116,6 +130,11 @@ if (LINK_EXTRA) endif() +# 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) + # Setup CMake ##################################################################### @@ -136,6 +155,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 ##################################################################### @@ -164,7 +188,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 @@ -191,7 +215,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" ) @@ -207,7 +231,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" ) @@ -240,14 +264,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" ) @@ -262,14 +286,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" ) @@ -497,6 +521,20 @@ 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") + 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 ##################################################################### @@ -614,7 +652,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