X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=CMakeLists.txt;h=9037c89b42840c35a93bf25fb87b65979c28c377;hp=b5164ca78455ca415ac2738ca8dd7cff92fb8dad;hb=02f740a0fed75951f474fc94c23901505a031c5b;hpb=30b159cb876a9495de42e9a3e70ca050516f0805 diff --git a/CMakeLists.txt b/CMakeLists.txt index b5164ca7..9037c89b 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -11,14 +11,8 @@ cmake_minimum_required(VERSION 3.5) # Tell CMake about or own modules set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake) -# Versions -set(QUASSEL_MAJOR 0) -set(QUASSEL_MINOR 13) -set(QUASSEL_PATCH 50) -set(QUASSEL_VERSION_STRING "0.14-pre") - -# Output CMake and Quassel versions as well as build type for debug reasons -message(STATUS "Building Quassel ${QUASSEL_VERSION_STRING}...") +include(QuasselVersion) + message(STATUS "Using CMake ${CMAKE_VERSION}") # Set up build type rather early @@ -113,8 +107,8 @@ if (NOT EMBED_DEFAULT) endif() # The following options are not for end-user consumption, so don't list them in the feature summary -cmake_dependent_option(DEPLOY "Add required libs to bundle resources and create a dmg. Note: requires Qt to be built with 10.4u SDK" OFF "APPLE" OFF) - +option(FATAL_WARNINGS "Make compile warnings fatal (most useful for CI builds)" OFF) +cmake_dependent_option(DEPLOY "Add required libs to bundle resources and create a dmg" OFF "APPLE" OFF) # List of authenticators and the cmake flags to build them # (currently that's just LDAP, but more can be added here). @@ -124,11 +118,25 @@ option(WITH_LDAP "Enable LDAP authentication support if present on system" ON) # Setup CMake ##################################################################### +# Visibility settings apply to all targets +if (POLICY CMP0063) + cmake_policy(SET CMP0063 NEW) +endif() + # Let automoc/autouic process generated files if (POLICY CMP0071) cmake_policy(SET CMP0071 NEW) endif() +set(BUILD_SHARED_LIBS TRUE CACHE BOOL "" FORCE) + +# Don't use X11 on OSX +if (APPLE) + set(CMAKE_DISABLE_FIND_PACKAGE_X11 true) + set(CMAKE_DISABLE_FIND_PACKAGE_XCB true) + set(CMAKE_DISABLE_FIND_PACKAGE_Qt5X11Extras true) +endif() + # Simplify later checks ##################################################################### @@ -139,7 +147,6 @@ if (WANT_MONO OR WANT_CORE) set(BUILD_CORE true) endif() - # Set up Qt ##################################################################### @@ -328,6 +335,14 @@ set_package_properties(Boost PROPERTIES TYPE REQUIRED URL "https://www.boost.org/" DESCRIPTION "Boost libraries for C++" ) +# Older versions don't define the imported target +if (NOT TARGET Boost::boost) + add_library(Boost::boost INTERFACE IMPORTED GLOBAL) + if (Boost_INCLUDE_DIRS) + set_target_properties(Boost::boost PROPERTIES + INTERFACE_INCLUDE_DIRECTORIES "${Boost_INCLUDE_DIRS}") + endif() +endif() find_package(ZLIB REQUIRED) set_package_properties(ZLIB PROPERTIES TYPE REQUIRED @@ -364,6 +379,9 @@ if (BUILD_TESTING) PURPOSE "Required for building unit tests" ) enable_testing() + + # GTest messes with CMAKE_CXX_FLAGS, so process them again + process_cmake_cxx_flags() endif() # Check for SSL support in Qt @@ -385,34 +403,17 @@ if (HAVE_SSL) endif() add_feature_info("SSL support in Qt" HAVE_SSL "Use secure network connections") -# Additional compile settings -##################################################################### - -# Needed to compile with mingw without kde -if (MINGW AND NOT WITH_KDE) - add_definitions(-D_WIN32_WINNT=0x0500) - message(STATUS "Added _WIN32_WINNT=0x0500 definition for MinGW") - # workaround for bug in mingw gcc 4.0 - add_definitions(-U__STRICT_ANSI__) -endif() - # Setup support for KDE Frameworks ##################################################################### -# We want to do this up here, so we have the necessary variables and defines set before -# compiling anything - if (WITH_KDE) + add_definitions(-DHAVE_KDE -DHAVE_KF5) + set(WITH_KF5 TRUE) + # If KDE Frameworks are present, they're most probably providing Qt5 integration including icon loading set(EMBED_DATA OFF) include(KDEInstallDirs) - include(KDECompilerSettings) - include(KDECMakeSettings) - - kde_enable_exceptions() - add_definitions(-DHAVE_KDE -DHAVE_KF5) - set(WITH_KF5 TRUE) endif() # This needs to come after setting up KDE integration, so we can use KDE-specific paths @@ -468,52 +469,10 @@ endif() if (WIN32) link_libraries(imm32 winmm dbghelp Secur32) # missing by default :/ if (MSVC) - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /DNOMINMAX") - set(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBUGINFO "/debug /INCREMENTAL:YES /NODEFAULTLIB:libcmt /DEFAULTLIB:msvcrt") - 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) endif() endif() - -# Generate version information from Git -##################################################################### - -include(GetGitRevisionDescription) -get_git_head_revision(GIT_REFSPEC GIT_HEAD) -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 -c log.showsignature=false show -s --format=%ct - WORKING_DIRECTORY ${CMAKE_SOURCE_DIR} - OUTPUT_VARIABLE GIT_COMMIT_DATE - OUTPUT_STRIP_TRAILING_WHITESPACE - ) -endif() - -# If not in a Git repo try to read GIT_HEAD and GIT_DESCRIBE from -# enviroment -if (NOT GIT_HEAD OR NOT GIT_DESCRIBE) - if (DEFINED ENV{GIT_HEAD}) - set(GIT_HEAD $ENV{GIT_HEAD}) - endif() - if (DEFINED ENV{GIT_DESCRIBE}) - set(GIT_DESCRIBE $ENV{GIT_DESCRIBE}) - endif() -endif() - -# Sanitize things if we're not in a Git repo -if (NOT GIT_HEAD OR NOT GIT_DESCRIBE) - set(GIT_HEAD "") - set(GIT_DESCRIBE "") - set(GIT_COMMIT_DATE 0) -endif() - -configure_file(version.h.in ${CMAKE_BINARY_DIR}/version.h @ONLY) - # Prepare the build #####################################################################