X-Git-Url: http://git.xonotic.org/?p=xonotic%2Fnetradiant.git;a=blobdiff_plain;f=CMakeLists.txt;h=c6cc4464a3dfb724ecb81eaf7a8f43b41535793d;hp=00e9814594206f19a44cec94df9d951c0069cb7d;hb=5980dc6b064efa71c7f39597abdab0665c378885;hpb=0311de363b4b54196e89d254fefbcb79d39342af diff --git a/CMakeLists.txt b/CMakeLists.txt index 00e98145..c6cc4464 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -2,36 +2,79 @@ cmake_minimum_required(VERSION 2.8.12 FATAL_ERROR) list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_LIST_DIR}/cmake") project(NetRadiant C CXX) +if (EXISTS "${PROJECT_SOURCE_DIR}/libs/crunch/inc/crn_decomp.h") + set(DEFAULT_BUILD_CRUNCH ON CACHE INTERNAL "...") +else () + set(DEFAULT_BUILD_CRUNCH OFF CACHE INTERNAL "...") +endif () + +if (EXISTS "${PROJECT_SOURCE_DIR}/tools/unvanquished/daemonmap/tools/quake3/q3map2/main.c") + set(DEFAULT_BUILD_DAEMONMAP ON CACHE INTERNAL "...") +else () + set(DEFAULT_BUILD_DAEMONMAP OFF CACHE INTERNAL "...") +endif () + option(BUILD_RADIANT "Build the GUI" ON) +option(BUILD_TOOLS "Build the tools" ON) +option(BUILD_CRUNCH "Build Crunch image support" ${DEFAULT_BUILD_CRUNCH}) +option(BUILD_DAEMONMAP "Build daemonmap navigation mesh generator" ${DEFAULT_BUILD_DAEMONMAP}) +option(DOWNLOAD_GAMEPACKS "Download game packs" ON) +option(USE_WERROR "Build with -Werror -pedantic-errors" OFF) +option(FHS_INSTALL "Install according to Filesystem Hierarchy Standard" OFF) + +set(BUILD_BINARIES OFF CACHE INTERNAL "...") +if (BUILD_RADIANT OR BUILD_TOOLS) + set(BUILD_BINARIES ON) +endif () + +#----------------------------------------------------------------------- +# Paths +#----------------------------------------------------------------------- if (CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) set(CMAKE_INSTALL_PREFIX "${PROJECT_SOURCE_DIR}/install" CACHE PATH "..." FORCE) endif () +set(RADIANT_NAME "NetRadiant" CACHE INTERNAL "...") +add_definitions(-DRADIANT_NAME="${RADIANT_NAME}") +set(RADIANT_BASENAME "netradiant" CACHE INTERNAL "...") +add_definitions(-DRADIANT_BASENAME="${RADIANT_BASENAME}") + +set(RADIANT_LIB_DIR ${CMAKE_INSTALL_PREFIX} CACHE INTERNAL "...") +set(RADIANT_BIN_DIR ${CMAKE_INSTALL_PREFIX} CACHE INTERNAL "...") +set(RADIANT_DATA_DIR ${CMAKE_INSTALL_PREFIX} CACHE INTERNAL "...") + +if (FHS_INSTALL AND NOT BUNDLE_LIBRARIES) + set(RADIANT_LIB_DIR ${CMAKE_INSTALL_PREFIX}/lib/${RADIANT_BASENAME}) + set(RADIANT_BIN_DIR ${CMAKE_INSTALL_PREFIX}/bin) + set(RADIANT_DATA_DIR ${CMAKE_INSTALL_PREFIX}/share/${RADIANT_BASENAME}) +endif () + +set(GAMEPACKS_DOWNLOAD_DIR ${PROJECT_BINARY_DIR}/download CACHE PATH "Where to store downloaded game packs") + #----------------------------------------------------------------------- # Version #----------------------------------------------------------------------- # CMake 3.0+ would allow this in project() -set(NetRadiant_VERSION_MAJOR 1) -set(NetRadiant_VERSION_MINOR 5) -set(NetRadiant_VERSION_PATCH 0) -set(NetRadiant_VERSION "${NetRadiant_VERSION_MAJOR}.${NetRadiant_VERSION_MINOR}.${NetRadiant_VERSION_PATCH}") - -file(WRITE "${PROJECT_BINARY_DIR}/RADIANT_MAJOR" ${NetRadiant_VERSION_MAJOR}) -file(WRITE "${PROJECT_BINARY_DIR}/RADIANT_MINOR" ${NetRadiant_VERSION_MINOR}) -file(WRITE "${PROJECT_BINARY_DIR}/RADIANT_PATCH" ${NetRadiant_VERSION_PATCH}) +set(RADIANT_VERSION_MAJOR 1) +set(RADIANT_VERSION_MINOR 5) +set(RADIANT_VERSION_PATCH 0) +set(RADIANT_VERSION "${RADIANT_VERSION_MAJOR}.${RADIANT_VERSION_MINOR}.${RADIANT_VERSION_PATCH}") set(RADIANT_ABOUTMSG "Custom build" CACHE STRING "About message") find_package(Git REQUIRED) + execute_process( - COMMAND ${GIT_EXECUTABLE} rev-parse --short HEAD - WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} - OUTPUT_VARIABLE GIT_VERSION - OUTPUT_STRIP_TRAILING_WHITESPACE + COMMAND ${GIT_EXECUTABLE} rev-parse --short HEAD + WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} + OUTPUT_VARIABLE GIT_VERSION + OUTPUT_STRIP_TRAILING_WHITESPACE ) -set(RADIANT_VERSION_STRING "${NetRadiant_VERSION}n") + +set(RADIANT_VERSION_STRING "${RADIANT_VERSION}n") + if (GIT_VERSION) set(RADIANT_VERSION_STRING "${RADIANT_VERSION_STRING}-git-${GIT_VERSION}") endif () @@ -42,19 +85,23 @@ message(STATUS "Building ${PROJECT_NAME} ${RADIANT_VERSION_STRING} ${RADIANT_ABO # Language standard #----------------------------------------------------------------------- -set(CMAKE_CXX_STANDARD 11) -set(CMAKE_CXX_STANDARD_REQUIRED ON) -if (CMAKE_VERSION VERSION_LESS "3.1") - if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang" OR CMAKE_COMPILER_IS_GNUCXX) - include(CheckCXXCompilerFlag) - check_cxx_compiler_flag(--std=c++${CMAKE_CXX_STANDARD} STD_CXX) - if (STD_CXX) - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} --std=c++${CMAKE_CXX_STANDARD}") +if (BUILD_BINARIES) + set(CMAKE_CXX_STANDARD 11) + set(CMAKE_CXX_STANDARD_REQUIRED ON) + set(CMAKE_CXX_EXTENSIONS OFF) + + if (CMAKE_VERSION VERSION_LESS "3.1") + if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang" OR CMAKE_COMPILER_IS_GNUCXX) + include(CheckCXXCompilerFlag) + check_cxx_compiler_flag(--std=c++${CMAKE_CXX_STANDARD} STD_CXX) + if (STD_CXX) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} --std=c++${CMAKE_CXX_STANDARD}") + else () + message(SEND_ERROR "Requires C++${CMAKE_CXX_STANDARD} or better") + endif () else () - message(SEND_ERROR "Requires C++${CMAKE_CXX_STANDARD} or better") + message(WARNING "Unrecognized compiler: ${CMAKE_CXX_COMPILER_ID}, make sure it supports C++${CMAKE_CXX_STANDARD}") endif () - else () - message(WARNING "Unrecognized compiler: ${CMAKE_CXX_COMPILER_ID}, make sure it supports C++${CMAKE_CXX_STANDARD}") endif () endif () @@ -62,119 +109,164 @@ endif () # Flags #----------------------------------------------------------------------- -set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-exceptions -fno-rtti") -macro(addflags_c args) - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${args}") -endmacro() -macro(addflags_cxx args) - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${args}") -endmacro() -macro(addflags args) - addflags_c("${args}") - addflags_cxx("${args}") -endmacro() -addflags("-fno-strict-aliasing") -if (NOT WIN32) - addflags("-fvisibility=hidden") -endif () +if (BUILD_BINARIES) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-exceptions -fno-rtti") -if ("${CMAKE_BUILD_TYPE}" STREQUAL "Debug") - addflags("-Werror") - addflags("-pedantic-errors") -endif () + macro (addflags_c args) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${args}") + endmacro () + + macro (addflags_cxx args) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${args}") + endmacro () + + macro (addflags args) + addflags_c("${args}") + addflags_cxx("${args}") + endmacro () -addflags("-Wall") -addflags("-Wextra") -addflags("-pedantic") + addflags("-fno-strict-aliasing") + if (NOT WIN32) + addflags("-fvisibility=hidden") + endif () + + if (USE_WERROR) + addflags("-Werror") + addflags("-pedantic-errors") + endif () -addflags_c("-Wno-deprecated-declarations") # vfs.c: g_strdown + addflags("-Wall") + addflags("-Wextra") + addflags("-pedantic") -addflags("-Wno-unused-function") -addflags("-Wno-unused-variable") -addflags("-Wno-unused-parameter") + addflags_c("-Wno-deprecated-declarations") # vfs.c: g_strdown -set(CMAKE_POSITION_INDEPENDENT_CODE 1) -set(GTK_TARGET 2 CACHE STRING "GTK target") -add_definitions(-DGTK_TARGET=${GTK_TARGET}) + addflags("-Wno-unused-function") + addflags("-Wno-unused-variable") + addflags("-Wno-unused-parameter") + + set(CMAKE_POSITION_INDEPENDENT_CODE 1) +endif () + +if (BUILD_RADIANT) + set(GTK_TARGET 2 CACHE STRING "GTK target") + add_definitions(-DGTK_TARGET=${GTK_TARGET}) + + if (WIN32) + add_definitions(-DWORKAROUND_WINDOWS_FLOATING_WINDOW=1) + + if (GTK_TARGET EQUAL 2) + add_definitions(-DWORKAROUND_WINDOWS_GTK2_GLWIDGET=1) + endif () + endif () +endif () #----------------------------------------------------------------------- # Defs #----------------------------------------------------------------------- -add_definitions(-DRADIANT_VERSION="${NetRadiant_VERSION}") -add_definitions(-DRADIANT_MAJOR_VERSION="${NetRadiant_VERSION_MAJOR}") -add_definitions(-DRADIANT_MINOR_VERSION="${NetRadiant_VERSION_MINOR}") -add_definitions(-DRADIANT_PATCH_VERSION="${NetRadiant_VERSION_PATCH}") +if (BUILD_BINARIES) + add_definitions(-DRADIANT_VERSION="${RADIANT_VERSION}") + add_definitions(-DRADIANT_VERSION_STRING="${RADIANT_VERSION_STRING}") -add_definitions(-DRADIANT_ABOUTMSG="${NetRadiant_ABOUT}") + if (NOT CMAKE_BUILD_TYPE MATCHES Release) + add_definitions(-D_DEBUG=1) + endif () +endif () -if (NOT CMAKE_BUILD_TYPE MATCHES Release) - add_definitions(-D_DEBUG=1) +if (BUILD_RADIANT) + add_definitions(-DRADIANT_ABOUTMSG="${RADIANT_ABOUTMSG}") + + macro (disable_deprecated name gtk2only) + add_definitions(-D${name}_DISABLE_SINGLE_INCLUDES) + if ((${gtk2only} EQUAL 0) OR (GTK_TARGET EQUAL 2)) + add_definitions(-D${name}_DISABLE_DEPRECATED) + endif () + endmacro () + + disable_deprecated(ATK 0) + disable_deprecated(G 0) + disable_deprecated(GDK 0) + disable_deprecated(GDK_PIXBUF 0) + disable_deprecated(GTK 1) + disable_deprecated(PANGO 0) endif () -macro(disable_deprecated name gtk2only) - add_definitions(-D${name}_DISABLE_SINGLE_INCLUDES) - if ((${gtk2only} EQUAL 0) OR (GTK_TARGET EQUAL 2)) - add_definitions(-D${name}_DISABLE_DEPRECATED) +if (BUILD_BINARIES) + add_custom_target(binaries ALL) + + if(APPLE OR ${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD") + link_directories( + /usr/local/lib + ) endif () -endmacro() - -disable_deprecated(ATK 0) -disable_deprecated(G 0) -disable_deprecated(GDK 0) -disable_deprecated(GDK_PIXBUF 0) -disable_deprecated(GTK 1) -disable_deprecated(PANGO 0) - -if (APPLE) - option(XWINDOWS "Build against X11" ON) - add_definitions( - -DPOSIX=1 - ) -elseif (WIN32) - add_definitions( + + if (WIN32) + add_definitions( -DWIN32=1 -D_WIN32=1 - ) -else () - set(XWINDOWS ON) - add_definitions( + ) + else () + add_definitions( -DPOSIX=1 - ) + ) + endif () endif () -if (XWINDOWS) +if (BUILD_RADIANT AND NOT APPLE AND NOT WIN32) + set(XWINDOWS ON) find_package(X11 REQUIRED) include_directories(${X11_INCLUDE_DIR}) add_definitions(-DXWINDOWS=1) endif () -include_directories("${PROJECT_SOURCE_DIR}/include") -include_directories("${PROJECT_SOURCE_DIR}/libs") +if (BUILD_BINARIES) + include_directories("${PROJECT_SOURCE_DIR}/include") + include_directories("${PROJECT_SOURCE_DIR}/libs") -if (WIN32 AND NOT CMAKE_CROSSCOMPILING) - set(BUNDLE_LIBRARIES_DEFAULT ON) -else () - set(BUNDLE_LIBRARIES_DEFAULT OFF) -endif () -option(BUNDLE_LIBRARIES "Bundle libraries" ${BUNDLE_LIBRARIES_DEFAULT}) + if (WIN32 OR "${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") + set(BUNDLING_SUPPORTED ON) + endif() -macro(copy_dlls target) - if (BUNDLE_LIBRARIES) - add_custom_command(TARGET ${target} POST_BUILD - COMMAND bash - ARGS -c "ldd '$' | grep -v /c/Windows | awk '{ print $1 }' | while read dll; do cp \"$(which $dll)\" '${PROJECT_BINARY_DIR}'; done" - VERBATIM - ) + if (BUNDLING_SUPPORTED) + if(WIN32 AND NOT CMAKE_CROSSCOMPILING) + set(BUNDLE_LIBRARIES_DEFAULT ON) + else () + set(BUNDLE_LIBRARIES_DEFAULT OFF) + endif () + + option(BUNDLE_LIBRARIES "Bundle libraries" ${BUNDLE_LIBRARIES_DEFAULT}) + endif () + + if (BUNDLE_LIBRARIES AND BUNDLING_SUPPORTED) + add_subdirectory(bundle) + + set(FHS_INSTALL OFF CACHE PATH "Disabled because of BUNDLE_LIBRARIES" FORCE) endif () -endmacro() + + macro (copy_dlls target) + if (BUNDLE_LIBRARIES AND BUNDLING_SUPPORTED) + add_custom_command(TARGET ${target} POST_BUILD + COMMAND "${PROJECT_SOURCE_DIR}/library-bundler" + "register" "${PROJECT_BINARY_DIR}" "$" + VERBATIM + ) + add_dependencies(bundle ${target}) + endif () + endmacro () +endif () #----------------------------------------------------------------------- # Libraries #----------------------------------------------------------------------- -add_subdirectory(libs) -add_subdirectory(include) +if (BUILD_BINARIES) + add_subdirectory(libs) +endif () + +if (BUILD_RADIANT) + add_subdirectory(include) +endif () #----------------------------------------------------------------------- # Plugins @@ -196,116 +288,105 @@ endif () # Radiant #----------------------------------------------------------------------- -if (CMAKE_EXECUTABLE_SUFFIX) - string(REGEX REPLACE "^[.]" "" RADIANT_EXECUTABLE ${CMAKE_EXECUTABLE_SUFFIX}) -else () - execute_process( - COMMAND uname -m - OUTPUT_VARIABLE RADIANT_EXECUTABLE - OUTPUT_STRIP_TRAILING_WHITESPACE - ) -endif () +if (BUILD_BINARIES) + macro (radiant_tool name) + add_dependencies(binaries ${name}) -macro(radiant_tool name) - add_executable(${name} ${ARGN}) - install( + if (WIN32) + add_executable(${name} ${ARGN} ${PROJECT_SOURCE_DIR}/include/lib.rc) + else () + add_executable(${name} ${ARGN}) + endif() + + copy_dlls(${name}) + + install( TARGETS ${name} - RUNTIME DESTINATION . - ) - if (NOT (CMAKE_EXECUTABLE_SUFFIX STREQUAL ".${RADIANT_EXECUTABLE}")) - add_custom_command(TARGET ${name} POST_BUILD - COMMAND ln -f -s "$" "${PROJECT_BINARY_DIR}/${name}.${RADIANT_EXECUTABLE}" - VERBATIM - ) - install(CODE "execute_process(COMMAND ${CMAKE_COMMAND} -E create_symlink - ${name}${CMAKE_EXECUTABLE_SUFFIX} ${CMAKE_INSTALL_PREFIX}/${name}.${RADIANT_EXECUTABLE}) - ") - endif () -endmacro() + RUNTIME DESTINATION ${RADIANT_BIN_DIR} + ) + endmacro () -if (BUILD_RADIANT) - add_subdirectory(radiant _radiant) - set_target_properties(radiant PROPERTIES - COMPILE_DEFINITIONS RADIANT_EXECUTABLE="${RADIANT_EXECUTABLE}" - ) + if (BUILD_RADIANT) + add_subdirectory(radiant) + endif () endif () #----------------------------------------------------------------------- # Tools #----------------------------------------------------------------------- -add_subdirectory(tools) +if (BUILD_TOOLS) + add_subdirectory(tools) -file(GLOB DATA_FILES "${PROJECT_SOURCE_DIR}/setup/data/tools/*") + file(GLOB DATA_FILES "${PROJECT_SOURCE_DIR}/setup/data/tools/*") -if (NOT (PROJECT_SOURCE_DIR STREQUAL PROJECT_BINARY_DIR)) - # Copy data files from sources to the build directory - message(STATUS "Copying data files") - file(COPY ${DATA_FILES} DESTINATION "${PROJECT_BINARY_DIR}") + if (NOT (PROJECT_SOURCE_DIR STREQUAL PROJECT_BINARY_DIR)) + # Copy data files from sources to the build directory + message(STATUS "Copying data files") + file(COPY ${DATA_FILES} DESTINATION "${PROJECT_BINARY_DIR}") + endif () endif () #----------------------------------------------------------------------- # Game packs #----------------------------------------------------------------------- -option(DOWNLOAD_GAMEPACKS "Download game packs" ON) -add_custom_target(game_packs - COMMAND ${CMAKE_COMMAND} -E make_directory games - COMMAND DOWNLOAD_GAMEPACKS=yes SOURCE_DIR="${PROJECT_SOURCE_DIR}" "${PROJECT_SOURCE_DIR}/install-gamepacks.sh" "${PROJECT_BINARY_DIR}" - COMMENT "Downloading game packs" - ) +set(GAMEPACKS_LICENSE_LIST free CACHE STRING "Download game packs by license") +set(GAMEPACKS_NAME_LIST none CACHE STRING "Download game packs by name") + if (DOWNLOAD_GAMEPACKS) - add_custom_target(game_packs_all ALL DEPENDS game_packs) + add_custom_target(gamepacks ALL + COMMAND "${PROJECT_SOURCE_DIR}/gamepack-manager" --license ${GAMEPACKS_LICENSE_LIST} --name ${GAMEPACKS_NAME_LIST} --download-dir "${GAMEPACKS_DOWNLOAD_DIR}" --install-dir "${PROJECT_BINARY_DIR}/gamepacks" --download --install + COMMENT "Downloading game packs" + ) endif () #----------------------------------------------------------------------- # Install #----------------------------------------------------------------------- -install( - FILES - "${PROJECT_BINARY_DIR}/RADIANT_MAJOR" - "${PROJECT_BINARY_DIR}/RADIANT_MINOR" - "${PROJECT_BINARY_DIR}/RADIANT_PATCH" - DESTINATION . -) - -install( - DIRECTORY - setup/data/tools/ +if (BUILD_BINARIES) + install(DIRECTORY + setup/data/tools/base + setup/data/tools/bitmaps + setup/data/tools/gl + setup/data/tools/plugins docs - DESTINATION . -) + DESTINATION ${RADIANT_DATA_DIR} + ) -set(GAME_FILES - DarkPlaces - Nexuiz - OpenArena - Osirion - Q3 - Quake2 - Quake - Quetoo - Tremulous - UFOAI - Unvanquished - Warsow - Xonotic - ) -unset(_tmp) -foreach (it ${GAME_FILES}) - set(dir "${PROJECT_BINARY_DIR}/games/${it}Pack") - string(TOLOWER "${it}" it) - list(APPEND _tmp "${dir}/games") - list(APPEND _tmp "${dir}/${it}.game") -endforeach () -set(GAME_FILES ${_tmp}) - -install( - DIRECTORY - ${GAME_FILES} - DESTINATION . - OPTIONAL -) + install(FILES + setup/data/tools/global.xlink + DESTINATION ${RADIANT_DATA_DIR} + ) +endif () + +if (DOWNLOAD_GAMEPACKS) + if (FHS_INSTALL) + set(GAME_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}/share/netradiant") + else () + set(GAME_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}") + endif () + + install(DIRECTORY + ${PROJECT_BINARY_DIR}/gamepacks + DESTINATION ${RADIANT_DATA_DIR} + ) +endif () + +if(BUILD_BINARIES AND FHS_INSTALL AND NOT WIN32 AND NOT APPLE) + install(FILES + ${PROJECT_SOURCE_DIR}/icons/netradiant.png + DESTINATION ${CMAKE_INSTALL_PREFIX}/share/pixmaps + ) + install(FILES + ${PROJECT_SOURCE_DIR}/icons/netradiant.desktop + DESTINATION ${CMAKE_INSTALL_PREFIX}/share/applications + ) + install(FILES + ${PROJECT_SOURCE_DIR}/icons/mime/map.xml + DESTINATION ${CMAKE_INSTALL_PREFIX}/share/mime/model + ) +endif () include(cmake/scripts/package.cmake)