X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=CMakeLists.txt;h=0f8a87ae862d8a4dd3c42193cf29fd411f230511;hp=f5e363234f4257a60f32ef2135ba293108524d26;hb=580662426b8b734566b37de61deccf5b89970c6e;hpb=f9f7524c41eb5668f3172cfddaa4d50badcd7fff diff --git a/CMakeLists.txt b/CMakeLists.txt index f5e36323..0f8a87ae 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -21,7 +21,8 @@ project(QuasselIRC) -cmake_minimum_required(VERSION 2.6.0 FATAL_ERROR) +# cmake 2.6.2 is required for KDE >=4.2 and should be widespread enough now +cmake_minimum_required(VERSION 2.6.2 FATAL_ERROR) if(COMMAND cmake_policy) cmake_policy(SET CMP0003 NEW) @@ -106,12 +107,20 @@ endif(NOT CMAKE_BUILD_TYPE) if(CMAKE_COMPILER_IS_GNUCXX) # Let's just hope that all gccs support these options and skip the tests... # -fno-strict-aliasing is needed apparently for Qt < 4.6 - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ansi -Wall -Wextra -Wnon-virtual-dtor -fno-strict-aliasing") - set(CMAKE_CXX_FLAGS_RELWITHDEBUGINFO "-O2") - set(CMAKE_CXX_FLAGS_DEBUG "-g -fno-reorder-blocks -fno-schedule-insns -fno-inline") - set(CMAKE_CXX_FLAGS_DEBUGFULL "-g3") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ansi -Wall -Wextra -Wnon-virtual-dtor -fno-strict-aliasing") + set(CMAKE_CXX_FLAGS_RELEASE "-O2 ${CMAKE_CXX_FLAGS}") + set(CMAKE_CXX_FLAGS_RELWITHDEBUGINFO "-g -O2 ${CMAKE_CXX_FLAGS}") + set(CMAKE_CXX_FLAGS_DEBUG "-g -ggdb -fno-reorder-blocks -fno-schedule-insns -fno-inline ${CMAKE_CXX_FLAGS}") + set(CMAKE_CXX_FLAGS_DEBUGFULL "-g3 ${CMAKE_CXX_FLAGS_DEBUG}") endif(CMAKE_COMPILER_IS_GNUCXX) +string(TOUPPER ${CMAKE_BUILD_TYPE} upper_build_type) +if(upper_build_type STREQUAL "RELEASE" OR upper_build_type STREQUAL "RELWITHDEBUGINFO") + add_definitions(-DNDEBUG -DQT_NO_DEBUG) +else(upper_build_type STREQUAL "RELEASE" OR upper_build_type STREQUAL "RELWITHDEBUGINFO") + set(DEBUG 1) +endif(upper_build_type STREQUAL "RELEASE" OR upper_build_type STREQUAL "RELWITHDEBUGINFO") + if(WANT_MONO OR WANT_QTCLIENT) set(QT_MIN_VERSION "4.5.0") else(WANT_MONO OR WANT_QTCLIENT) @@ -147,25 +156,22 @@ include(${QT_USE_FILE}) include_directories(${QT_INCLUDES}) # Setup OpenSSL +# We don't link to or include OpenSSL ourselves, but use exclusively the Qt API. +# Thus, we simply check if OpenSSL support is present in Qt's config and enable our +# own SSL stuff in this case. Qt should care for adding what it needs itself. if(WITH_OPENSSL) - find_package(OpenSSL) + if(QT_QCONFIG MATCHES "openssl") + message(STATUS "Found OpenSSL support in Qt, enabling SSL") + add_definitions(-DHAVE_SSL) + set(HAVE_SSL true) + else(QT_QCONFIG MATCHES "openssl") + message(STATUS "No OpenSSL support found in Qt, disabling SSL") + add_definitions(-DQT_NO_OPENSSL) + endif(QT_QCONFIG MATCHES "openssl") else(WITH_OPENSSL) message(STATUS "Not enabling OpenSSL support") endif(WITH_OPENSSL) -if(OPENSSL_FOUND) - if(NOT QT_DEFINITIONS MATCHES "QT_NO_OPENSSL") - message(STATUS "Found OpenSSL support in Qt") - add_definitions(-DHAVE_SSL) - set(HAVE_SSL true) - set(MOC_DEFINES ${MOC_DEFINES} -DHAVE_SSL) - else(NOT QT_DEFINITIONS MATCHES "QT_NO_OPENSSL") - message(STATUS "No OpenSSL support found in Qt, disabling") - endif(NOT QT_DEFINITIONS MATCHES "QT_NO_OPENSSL") -else(OPENSSL_FOUND) - add_definitions(-DQT_NO_OPENSSL) -endif(OPENSSL_FOUND) - # Setup D-Bus support if(WITH_DBUS) if(QT_QTDBUS_FOUND) @@ -173,7 +179,6 @@ if(WITH_DBUS) add_definitions(-DHAVE_DBUS) set(LINK_DBUS DBUS) set(HAVE_DBUS true) - set(MOC_DEFINES ${MOC_DEFINES} -DHAVE_DBUS) else(QT_QTDBUS_FOUND) message(STATUS "QtDBus not found, disabling D-Bus support") endif(QT_QTDBUS_FOUND) @@ -188,7 +193,6 @@ if(WITH_WEBKIT) add_definitions(-DHAVE_WEBKIT) set(LINK_WEBKIT WEBKIT) set(HAVE_WEBKIT true) - set(MOC_DEFINES ${MOC_DEFINES} -DHAVE_WEBKIT) else(QT_QTWEBKIT_FOUND) message(STATUS "QtWebKit not found, disabling WebKit support") endif(QT_QTWEBKIT_FOUND) @@ -204,7 +208,6 @@ if(WITH_KDE) include_directories(${KDE4_INCLUDES}) add_definitions(-DHAVE_KDE ${KDE4_DEFINITIONS}) set(HAVE_KDE 1) - set(MOC_DEFINES ${MOC_DEFINES} -DHAVE_KDE) set(QUASSEL_KDE_LIBRARIES ${KDE4_KDECORE_LIBS} ${KDE4_KDEUI_LIBRARY} ${KDE4_SOLID_LIBS} knotifyconfig) # We always use external icons for KDE4 support, since we use its iconloader rather than our own set(EMBED_DATA OFF) @@ -223,7 +226,6 @@ if(NOT HAVE_KDE) message(STATUS "Enabling Phonon support") add_definitions(-DHAVE_PHONON) set(HAVE_PHONON true) - set(MOC_DEFINES ${MOC_DEFINES} -DHAVE_PHONON) else(PHONON_FOUND) message(STATUS "Phonon not found, disabling audio notifications") endif(PHONON_FOUND) @@ -288,19 +290,14 @@ endif(STATIC AND CMAKE_COMPILER_IS_GNUCXX) if(WIN32) link_libraries(imm32 winmm dbghelp Secur32) # missing by default :/ - if(HAVE_SSL) + if(HAVE_SSL AND STATIC) + find_package(OpenSSL REQUIRED) link_libraries(${OPENSSL_LIBRARIES} libeay32MD) - endif(HAVE_SSL) + endif(HAVE_SSL AND STATIC) endif(WIN32) if(INDICATEQT_FOUND) - if(WANT_QTCLIENT) - set(DESKTOP_FILE ${XDG_APPS_INSTALL_DIR}/quasselclient.desktop) - endif(WANT_QTCLIENT) - if(WANT_MONO) - set(DESKTOP_FILE ${XDG_APPS_INSTALL_DIR}/quassel.desktop) - endif(WANT_MONO) - add_definitions(-DDESKTOP_FILE=${DESKTOP_FILE}) + add_definitions(-DXDG_APPS_INSTALL_DIR=${XDG_APPS_INSTALL_DIR}) endif(INDICATEQT_FOUND) # We need to create a version.gen