Use options to choose which targets to build, instead of the BUILD variable.
authorDiego 'Flameeyes' Pettenò <flameeyes@gmail.com>
Mon, 16 Jun 2008 15:49:46 +0000 (17:49 +0200)
committerManuel Nickschas <sputnick@quassel-irc.org>
Mon, 16 Jun 2008 15:54:12 +0000 (17:54 +0200)
Instead of a single space-separated list of targets to build, use
options to decide whether to enable the targets or not.

This also simplifies writing ebuilds for quassel.

Signed-off-by: Manuel Nickschas <sputnick@quassel-irc.org>
CMakeLists.txt
INSTALL.cmake

index bf34d35..eab6ada 100644 (file)
@@ -1,7 +1,7 @@
 # This is the cmake-based build system for Quassel IRC.
 # You may pass various options to cmake:
 # This is the cmake-based build system for Quassel IRC.
 # You may pass various options to cmake:
-# -DBUILD=<string> : Select binaries to build. <string> may contain any combination
-#                    of "core", "client", "mono" or "all".
+# -DWANT_(CORE|QTCLIENT|MONO)=(ON|OFF)
+#                  : select binaries to build
 # -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.
 # -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.
@@ -38,32 +38,9 @@ endif(ansi)
 
 set(QT_MIN_VERSION "4.3.0")
 
 
 set(QT_MIN_VERSION "4.3.0")
 
-# By default, we build all binaries
-if(NOT DEFINED BUILD)
-  set(BUILD all)
-endif(NOT DEFINED BUILD)
-
-# User might define which binaries to build by invoking cmake -DBUILD=<string>,
-# where <string> might contain any combination of "core", "client", "mono" or "all"
-if(BUILD MATCHES all)
-  set(BUILD_CORE true)
-  set(BUILD_QTCLIENT true)
-  set(BUILD_MONO true)
-  message(STATUS "Building Quassel Client, Quassel Core and monolithic Quassel.")
-else(BUILD MATCHES all)
-  if(BUILD MATCHES core)
-    set(BUILD_CORE true)
-    message(STATUS "Building Quassel Core")
-  endif(BUILD MATCHES core)
-  if(BUILD MATCHES client)
-    set(BUILD_QTCLIENT true)
-    message(STATUS "Building Quassel Client")
-  endif(BUILD MATCHES client)
-  if(BUILD MATCHES mono)
-    set(BUILD_MONO true)
-    message(STATUS "Building monolithic Quassel")
-  endif(BUILD MATCHES mono)
-endif(BUILD MATCHES all)
+option(WANT_CORE     "Build the core (server) binary"           ON)
+option(WANT_QTCLIENT "Build the Qt4 GUI client binary"          ON)
+option(WANT_MONO     "Build the monolithic (all-in-one) binary" ON)
 
 # Enable mostly b0rked stuff (new ChatView), do not enable this unless you know what you do...
 if(SPUTDEV)
 
 # Enable mostly b0rked stuff (new ChatView), do not enable this unless you know what you do...
 if(SPUTDEV)
@@ -99,18 +76,18 @@ add_dependencies(genversion_run genversion)
 # Add needed subdirs
 add_subdirectory(src/common)
 include_directories(src/common)
 # Add needed subdirs
 add_subdirectory(src/common)
 include_directories(src/common)
-if(BUILD_CORE OR BUILD_MONO)
+if(WANT_CORE OR WANT_MONO)
   add_subdirectory(src/core)
   include_directories(src/core)
   add_subdirectory(src/core)
   include_directories(src/core)
-endif(BUILD_CORE OR BUILD_MONO)
-if(BUILD_QTCLIENT OR BUILD_MONO)
+endif(WANT_CORE OR WANT_MONO)
+if(WANT_QTCLIENT OR WANT_MONO)
   add_subdirectory(src/client)
   add_subdirectory(src/uisupport)
   add_subdirectory(src/qtui)
   include_directories(src/client)
   include_directories(src/uisupport)
   include_directories(src/qtui)
   add_subdirectory(src/client)
   add_subdirectory(src/uisupport)
   add_subdirectory(src/qtui)
   include_directories(src/client)
   include_directories(src/uisupport)
   include_directories(src/qtui)
-endif(BUILD_QTCLIENT OR BUILD_MONO)
+endif(WANT_QTCLIENT OR WANT_MONO)
 
 # Make sure version.gen exists before building mod_common
 add_dependencies(mod_common genversion_run)
 
 # Make sure version.gen exists before building mod_common
 add_dependencies(mod_common genversion_run)
@@ -152,32 +129,32 @@ macro(setup_qt4_variables)
 endmacro(setup_qt4_variables)
 
 # Now we have everything, so just glue the right pieces together :)
 endmacro(setup_qt4_variables)
 
 # Now we have everything, so just glue the right pieces together :)
-if(BUILD_CORE)
+if(WANT_CORE)
   setup_qt4_variables(NETWORK SCRIPT SQL)
   add_executable(quasselcore ${CMAKE_SOURCE_DIR}/src/common/main.cpp
                              ${RC_SQL} ${RC_I18N} ${WIN32_RC})
   set_target_properties(quasselcore PROPERTIES 
                                     COMPILE_FLAGS "-DQT_NETWORK_LIB -DQT_SCRIPT_LIB -DQT_SQL_LIB -DBUILD_CORE")
   target_link_libraries(quasselcore mod_core mod_common ${QUASSEL_QT_LIBRARIES})
   setup_qt4_variables(NETWORK SCRIPT SQL)
   add_executable(quasselcore ${CMAKE_SOURCE_DIR}/src/common/main.cpp
                              ${RC_SQL} ${RC_I18N} ${WIN32_RC})
   set_target_properties(quasselcore PROPERTIES 
                                     COMPILE_FLAGS "-DQT_NETWORK_LIB -DQT_SCRIPT_LIB -DQT_SQL_LIB -DBUILD_CORE")
   target_link_libraries(quasselcore mod_core mod_common ${QUASSEL_QT_LIBRARIES})
-endif(BUILD_CORE)
+endif(WANT_CORE)
 
 
-if(BUILD_QTCLIENT)
+if(WANT_QTCLIENT)
   setup_qt4_variables(GUI NETWORK)
   add_executable(quasselclient ${CMAKE_SOURCE_DIR}/src/common/main.cpp
                                ${RC_ICONS} ${RC_QUASSEL_ICONS} ${RC_I18N} ${WIN32_RC})
   set_target_properties(quasselclient PROPERTIES
                                       COMPILE_FLAGS "-DQT_GUI_LIB -DQT_NETWORK_LIB -DBUILD_QTUI")
   target_link_libraries(quasselclient mod_qtui mod_uisupport mod_client mod_common ${QUASSEL_QT_LIBRARIES})
   setup_qt4_variables(GUI NETWORK)
   add_executable(quasselclient ${CMAKE_SOURCE_DIR}/src/common/main.cpp
                                ${RC_ICONS} ${RC_QUASSEL_ICONS} ${RC_I18N} ${WIN32_RC})
   set_target_properties(quasselclient PROPERTIES
                                       COMPILE_FLAGS "-DQT_GUI_LIB -DQT_NETWORK_LIB -DBUILD_QTUI")
   target_link_libraries(quasselclient mod_qtui mod_uisupport mod_client mod_common ${QUASSEL_QT_LIBRARIES})
-endif(BUILD_QTCLIENT)
+endif(WANT_QTCLIENT)
 
 
-if(BUILD_MONO)
+if(WANT_MONO)
   setup_qt4_variables(GUI NETWORK SCRIPT SQL)
   add_executable(quassel ${CMAKE_SOURCE_DIR}/src/common/main.cpp
                          ${RC_ICONS} ${RC_QUASSEL_ICONS} ${RC_SQL} ${RC_I18N} ${WIN32_RC})
   set_target_properties(quassel PROPERTIES 
                                 COMPILE_FLAGS "-DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SCRIPT_LIB -DQT_SQL_LIB -DBUILD_MONO")
   target_link_libraries(quassel mod_qtui mod_uisupport mod_client mod_core mod_common ${QUASSEL_QT_LIBRARIES})
   setup_qt4_variables(GUI NETWORK SCRIPT SQL)
   add_executable(quassel ${CMAKE_SOURCE_DIR}/src/common/main.cpp
                          ${RC_ICONS} ${RC_QUASSEL_ICONS} ${RC_SQL} ${RC_I18N} ${WIN32_RC})
   set_target_properties(quassel PROPERTIES 
                                 COMPILE_FLAGS "-DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_SCRIPT_LIB -DQT_SQL_LIB -DBUILD_MONO")
   target_link_libraries(quassel mod_qtui mod_uisupport mod_client mod_core mod_common ${QUASSEL_QT_LIBRARIES})
-endif(BUILD_MONO)
+endif(WANT_MONO)
 
 # Build bundles for MacOSX
 if(APPLE)
 
 # Build bundles for MacOSX
 if(APPLE)
@@ -190,23 +167,23 @@ if(APPLE)
 endif(APPLE)
 
 # Install rules
 endif(APPLE)
 
 # Install rules
-if(BUILD_CORE)
+if(WANT_CORE)
   install(TARGETS quasselcore
           RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/bin)
   install(TARGETS quasselcore
           RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/bin)
-endif(BUILD_CORE)
+endif(WANT_CORE)
 
 
-if(BUILD_QTCLIENT)
+if(WANT_QTCLIENT)
   install(TARGETS quasselclient
           RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/bin)
 
   install(FILES quasselclient.desktop
           DESTINATION ${CMAKE_INSTALL_PREFIX}/share/applications)
   install(TARGETS quasselclient
           RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/bin)
 
   install(FILES quasselclient.desktop
           DESTINATION ${CMAKE_INSTALL_PREFIX}/share/applications)
-endif(BUILD_QTCLIENT)
+endif(WANT_QTCLIENT)
 
 
-if(BUILD_MONO)
+if(WANT_MONO)
   install(TARGETS quassel
           RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/bin)
 
   install(FILES quassel.desktop
           DESTINATION ${CMAKE_INSTALL_PREFIX}/share/applications)
   install(TARGETS quassel
           RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/bin)
 
   install(FILES quassel.desktop
           DESTINATION ${CMAKE_INSTALL_PREFIX}/share/applications)
-endif(BUILD_MONO)
+endif(WANT_MONO)
index 28a6c39..1555d4b 100644 (file)
@@ -20,9 +20,8 @@ NOTE: In order to reconfigure, you need to remove CMakeCache.txt (or empty
 
 Quassel recognizes the following options:
 
 
 Quassel recognizes the following options:
 
--DBUILD=<string>
-    Specify which Quassel binaries to build. <string> may contain any combination of
-    "core", "client", "mono" or "all".
+-DWANT_(CORE|QTCLIENT|MONO)=(ON|OFF)
+    Allow to choose which Quassel binaries to build.
 
 -DQT=/path/to/qt
     Use a non-system Qt installation. This is for example useful if you have a static
 
 -DQT=/path/to/qt
     Use a non-system Qt installation. This is for example useful if you have a static