X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=CMakeLists.txt;h=c6659ae683b747c2d071865589603c6a4781379c;hp=6963dfc7dcea3e195daa4185b40c621691b5dbec;hb=4549671a24de95dd6a2704bdefca957b864df7d8;hpb=3982589b93aa14c3cede148b8a5158b63055d65c diff --git a/CMakeLists.txt b/CMakeLists.txt index 6963dfc7..c6659ae6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -4,6 +4,7 @@ # of "core", "client", "mono" or "all". # -DQT=/path/to/qt : Choose a Qt4 installation to use instead of the system Qt4 # -DSTATIC=1 : Enable static building of Quassel, most useful with a static Qt. +# -DSTATICWIN=1 : Enable static building for Windows. # -DSPUTDEV : Do not use. # # NOTE: You need to remove CMakeCache.txt if you plan to change any of these values! @@ -11,6 +12,11 @@ project(QuasselIRC) cmake_minimum_required(VERSION 2.4.5) +cmake_policy(SET CMP0003 OLD) # suppress linker warnings + +if(STATICWIN) + set(CMAKE_BUILD_TYPE Release) +endif(STATICWIN) set(QT_MIN_VERSION "4.4.0") @@ -56,6 +62,19 @@ endif(SPUTDEV) # Now that we have the correct $PATH, lets find Qt! find_package(Qt4 REQUIRED) +set(QT_DONT_USE_QTGUI 1) +include(${QT_USE_FILE}) +include_directories(${QT_INCLUDES}) + +# We need to create a version.gen +# For this, we create our genversion binary and make sure it is run every time. +add_executable(genversion ${CMAKE_SOURCE_DIR}/src/common/genversion.cpp) +target_link_libraries(genversion ${QT_LIBRARIES}) + +add_custom_target(genversion_run ALL ${CMAKE_BINARY_DIR}/genversion + ${CMAKE_SOURCE_DIR} ${CMAKE_BINARY_DIR}/src/common/version.gen) +add_dependencies(genversion_run genversion) + # Add needed subdirs add_subdirectory(src/common) include_directories(src/common) @@ -72,6 +91,9 @@ if(BUILD_QTCLIENT OR BUILD_MONO) include_directories(src/qtui) endif(BUILD_QTCLIENT OR BUILD_MONO) +# Make sure version.gen exists before building mod_common +add_dependencies(mod_common genversion_run) + # Add resources qt4_add_resources(RES_I18N ${CMAKE_SOURCE_DIR}/i18n/i18n.qrc) qt4_add_resources(RES_ICONS ${CMAKE_SOURCE_DIR}/src/icons/icons.qrc) @@ -83,22 +105,17 @@ if(DEFINED STATIC) link_directories(${CMAKE_BINARY_DIR}/staticlibs) endif(DEFINED STATIC) -# Here comes the dirty part. Our targets need different Qt4 modules, i.e. different libs -# and defines. We can't simply include UseQt4 several times, since definitions add up. -# We workaround this by only setting up QtCore first, and adding additional stuff later. -set(QT_DONT_USE_QTGUI 1) -include(${QT_USE_FILE}) -include_directories(${QT_INCLUDES}) +if(STATICWIN AND WIN32) + link_libraries(imm32 winmm) # missing by default :/ +endif(STATICWIN AND WIN32) -# We need to create a version.gen -# For this, we create our genversion binary and make sure it is run every time. -add_executable(genversion ${CMAKE_SOURCE_DIR}/src/common/genversion.cpp) -target_link_libraries(genversion ${QT_LIBRARIES}) +# FIXME: Add icons for windows as soon as we have merged with trunk (which has reorganized +# the icon files): +# Simply add the .rc file to the targets -add_custom_target(genversion_run ALL ${CMAKE_BINARY_DIR}/genversion - ${CMAKE_SOURCE_DIR} ${CMAKE_BINARY_DIR}/src/common/version.gen) -add_dependencies(genversion_run genversion) -set_source_files_properties(src/common/global.cpp PROPERTIES OBJECT_DEPENDS genversion_run) +# Here comes the dirty part. Our targets need different Qt4 modules, i.e. different libs +# and defines. We can't simply include UseQt4 several times, since definitions add up. +# We workaround this by using our own macro to figure out what to add. # This macro sets variables for additional Qt modules. macro(setup_qt4_variables)