X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=CMakeLists.txt;h=7e083638b63c6099553b74af7d8fd66dcf7591d8;hb=99de2a2a15d5f7e2add891d2574667d840077ae4;hp=5c388a5e06aff4927fec687bf009bee95a0bfc2e;hpb=b09c226691a731ec3da332a9fad491eb19e0ba0f;p=xonotic%2Fnetradiant.git diff --git a/CMakeLists.txt b/CMakeLists.txt index 5c388a5e..7e083638 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,10 +1,66 @@ -cmake_minimum_required(VERSION 2.8.12 FATAL_ERROR) -list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_LIST_DIR}/cmake") +cmake_minimum_required(VERSION 3.1 FATAL_ERROR) + project(NetRadiant C CXX) +#----------------------------------------------------------------------- +# Builtins: configuration +#----------------------------------------------------------------------- + +set(BUILTINS_INSTALL_DIR "${CMAKE_BINARY_DIR}/builtins") +set(BUILTINS_INCLUDE_DIR "${BUILTINS_INSTALL_DIR}/include") +set(BUILTINS_LIB_DIR "${BUILTINS_INSTALL_DIR}/lib") +set(BUILTINS_PKGCONFIG_DIR "${BUILTINS_INSTALL_DIR}/lib/pkgconfig") + +option(BUILTIN_GTKGLEXT "Builtin GtkGLExt" OFF) + +set(BUILTIN_GTKGLEXT_BUILT OFF CACHE INTERNAL "...") +if (EXISTS "${BUILTINS_INSTALL_DIR}/lib/pkgconfig/gtkglext-1.0.pc") + set(BUILTIN_GTKGLEXT_BUILT ON) +endif () + +if (EXISTS "${BUILTINS_INCLUDE_DIR}") + include_directories("${BUILTINS_INCLUDE_DIR}") +endif () + +if (EXISTS "${BUILTINS_LIB_DIR}") + set(ENV{LD_LIBRARY_PATH} "$ENV{LD_LIBRARY_PATH}:${BUILTINS_LIB_DIR}") + link_directories("${BUILTINS_LIB_DIR}") +endif () + +if (EXISTS "${BUILTINS_PKGCONFIG_DIR}") + set(ENV{PKG_CONFIG_PATH} "$ENV{PKG_CONFIG_PATH}:${BUILTINS_PKGCONFIG_DIR}") +endif () + +#----------------------------------------------------------------------- +# CMake modules +#----------------------------------------------------------------------- + +list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_LIST_DIR}/cmake") + +#----------------------------------------------------------------------- +# Submodules +#----------------------------------------------------------------------- + +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 () + +#----------------------------------------------------------------------- +# Build options +#----------------------------------------------------------------------- + option(BUILD_RADIANT "Build the GUI" ON) option(BUILD_TOOLS "Build the tools" ON) -option(BUILD_CRUNCH "Build Crunch image support" OFF) +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) @@ -14,6 +70,26 @@ if (BUILD_RADIANT OR BUILD_TOOLS) set(BUILD_BINARIES ON) endif () +if (BUILD_BINARIES) + if (WIN32 OR APPLE OR "${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") + set(BUNDLING_SUPPORTED ON) + endif() + + 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) + set(FHS_INSTALL OFF CACHE PATH "Disabled because of BUNDLE_LIBRARIES" FORCE) + endif () +endif () + #----------------------------------------------------------------------- # Paths #----------------------------------------------------------------------- @@ -22,19 +98,32 @@ if (CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) set(CMAKE_INSTALL_PREFIX "${PROJECT_SOURCE_DIR}/install" CACHE PATH "..." FORCE) endif () +if (APPLE) + set(APPLE_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX}/NetRadiant.app) + set(FINAL_INSTALL_PREFIX ${APPLE_INSTALL_PREFIX}/Contents/Prefix) +else () + set(FINAL_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX}) +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) - 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}) +set(RADIANT_BIN_DIR ${FINAL_INSTALL_PREFIX} CACHE INTERNAL "...") +set(RADIANT_LIB_DIR ${FINAL_INSTALL_PREFIX}/lib CACHE INTERNAL "...") +set(RADIANT_ADDONS_DIR ${FINAL_INSTALL_PREFIX} CACHE INTERNAL "...") +set(RADIANT_ETC_DIR ${FINAL_INSTALL_PREFIX}/etc CACHE INTERNAL "...") +set(RADIANT_SHARE_DIR ${FINAL_INSTALL_PREFIX}/share CACHE INTERNAL "...") +set(RADIANT_DATA_DIR ${FINAL_INSTALL_PREFIX} CACHE INTERNAL "...") + +if (FHS_INSTALL AND NOT BUNDLE_LIBRARIES) + set(RADIANT_BIN_DIR ${FINAL_INSTALL_PREFIX}/bin) + set(RADIANT_LIB_DIR ${FINAL_INSTALL_PREFIX}/lib) + set(RADIANT_ADDONS_DIR ${RADIANT_LIB_DIR}/${RADIANT_BASENAME}) + set(RADIANT_ETC_DIR ${FINAL_INSTALL_PREFIX}/etc) + set(RADIANT_SHARE_DIR ${FINAL_INSTALL_PREFIX}/share) + set(RADIANT_DATA_DIR ${RADIANT_SHARE_DIR}/${RADIANT_BASENAME}) endif () set(GAMEPACKS_DOWNLOAD_DIR ${PROJECT_BINARY_DIR}/download CACHE PATH "Where to store downloaded game packs") @@ -138,6 +227,20 @@ 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 () + + if (APPLE) + if (GTK_TARGET EQUAL 2) + add_definitions(-DWORKAROUND_MACOS_GTK2_DESTROY=1) + endif () + endif () endif () #----------------------------------------------------------------------- @@ -172,6 +275,8 @@ if (BUILD_RADIANT) endif () if (BUILD_BINARIES) + add_custom_target(binaries ALL) + if(APPLE OR ${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD") link_directories( /usr/local/lib @@ -201,48 +306,79 @@ 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}) - macro (copy_dlls target) - if (BUNDLE_LIBRARIES AND WIN32) + if (BUNDLE_LIBRARIES AND BUNDLING_SUPPORTED) add_custom_command(TARGET ${target} POST_BUILD - COMMAND bash - ARGS -c "ldd '$' | egrep -i '\\.dll ' | grep -iv '/c/Windows' | awk '{ print $1 }' | while read dll; do dllbasename=\"$(which \"$dll\")\"; [ -f \"${PROJECT_BINARY_DIR}/$dllbasename\" ] || cp --preserve=timestamps \"$dllbasename\" '${PROJECT_BINARY_DIR}'; done" + COMMAND "${PROJECT_SOURCE_DIR}/library-bundler" + "register" "${PROJECT_BINARY_DIR}" "$" VERBATIM - ) + ) + add_dependencies(bundle ${target}) endif () endmacro () +endif () - macro (bundle_stuff target) - if (BUNDLE_LIBRARIES AND WIN32) - add_custom_command(TARGET ${target} POST_BUILD - COMMAND bash - ARGS -c "mkdir -p '${PROJECT_BINARY_DIR}/share/themes'; mkdir -p '${PROJECT_BINARY_DIR}/lib'; mingw=\"$(echo '${CMAKE_C_COMPILER}' | sed -e 's|/bin/.*||')\"; [ -d '${PROJECT_BINARY_DIR}/share/themes/MS-Windows' ] || cp -r --preserve=timestamps \"$mingw/share/themes/MS-Windows\" '${PROJECT_BINARY_DIR}/share/themes/'; [ -d '${PROJECT_BINARY_DIR}/lib/gdk-pixbuf-2.0' ] || cp -r --preserve=timestamps \"$mingw/lib/gdk-pixbuf-2.0\" '${PROJECT_BINARY_DIR}/lib/'; [ -d '${PROJECT_BINARY_DIR}/lib/gtk-2.0' ] || cp -r --preserve=timestamps \"$mingw/lib/gtk-2.0\" '${PROJECT_BINARY_DIR}/lib/'" - VERBATIM - ) +#----------------------------------------------------------------------- +# Bundle +#----------------------------------------------------------------------- + +if (BUILD_BINARIES) + if (BUNDLE_LIBRARIES AND BUNDLING_SUPPORTED) + add_subdirectory(bundle) + endif () +endif () - file(GLOB DLL_FILES ${PROJECT_BINARY_DIR}/*.dll) +#----------------------------------------------------------------------- +# Builtins: targets +#----------------------------------------------------------------------- - install(FILES - ${DLL_FILES} - DESTINATION ${CMAKE_INSTALL_PREFIX} - ) +add_custom_target(builtins) - install(DIRECTORY - ${PROJECT_BINARY_DIR}/lib - ${PROJECT_BINARY_DIR}/share - DESTINATION ${CMAKE_INSTALL_PREFIX} - ) - endif () - endmacro () +if (BUILTIN_GTKGLEXT) + include(${CMAKE_ROOT}/Modules/ExternalProject.cmake) + + execute_process(COMMAND pkg-config --libs gdk-2.0 gtk+-2.0 glib-2.0 gl + OUTPUT_VARIABLE GTKGLEXT_LDFLAGS + OUTPUT_STRIP_TRAILING_WHITESPACE + ) + set(GTKGLEXT_LDFLAGS "$ENV{LDFLAGS} -lm ${GTKGLEXT_LDFLAGS}") + + if (NOT CMAKE_BUILD_TYPE MATCHES Release) + set(GTKGLEXT_CFLAGS "$ENV{CFLAGS} -g") + else () + set(GTKGLEXT_CFLAGS "$ENV{CFLAGS}") + endif() + + set(CONFIGURE_OPTIONS --disable-gtk-doc --disable-gtk-doc-html --disable-gtk-doc-pdf) + + if (APPLE) + set(GTKGLEXT_GIT_TAG macos) + else () + set(GTKGLEXT_GIT_TAG fixes) + endif () + + ExternalProject_Add(gtkglext + GIT_REPOSITORY https://gitlab.gnome.org/illwieckz/gtkglext.git + GIT_TAG ${GTKGLEXT_GIT_TAG} + BUILD_IN_SOURCE ON + CONFIGURE_COMMAND export LDFLAGS=${GTKGLEXT_LDFLAGS} + CONFIGURE_COMMAND && NOCONFIGURE=1 ./autogen.sh + CONFIGURE_COMMAND && ./configure --prefix "${BUILTINS_INSTALL_DIR}" ${CONFIGURE_OPTIONS} + BUILD_COMMAND $(MAKE) CFLAGS=${GTKGLEXT_CFLAGS} LDFLAGS=${GTKGLEXT_LDFLAGS} + INSTALL_COMMAND $(MAKE) install + ) + + include_directories("${BUILTINS_INSTALL_DIR}/lib/gtkglext-1.0/include") + include_directories("${BUILTINS_INSTALL_DIR}/include/gtkglext-1.0") + + add_dependencies(builtins gtkglext) + set_target_properties(gtkglext PROPERTIES EXCLUDE_FROM_ALL ON) endif () +if (BUNDLE_LIBRARIES AND EXISTS ${BUILTINS_LIB_DIR}) + set(CMAKE_SKIP_BUILD_RPATH ON) +endif() + #----------------------------------------------------------------------- # Libraries #----------------------------------------------------------------------- @@ -276,12 +412,14 @@ endif () #----------------------------------------------------------------------- if (BUILD_BINARIES) - if (CMAKE_EXECUTABLE_SUFFIX) - string(REGEX REPLACE "^[.]" "" RADIANT_EXECUTABLE ${CMAKE_EXECUTABLE_SUFFIX}) - endif () - macro (radiant_tool name) - add_executable(${name} ${ARGN}) + add_dependencies(binaries ${name}) + + if (WIN32) + add_executable(${name} ${ARGN} ${PROJECT_SOURCE_DIR}/include/lib.rc) + else () + add_executable(${name} ${ARGN}) + endif() copy_dlls(${name}) @@ -293,9 +431,6 @@ if (BUILD_BINARIES) if (BUILD_RADIANT) add_subdirectory(radiant) - set_target_properties(${RADIANT_BASENAME} PROPERTIES - COMPILE_DEFINITIONS RADIANT_EXECUTABLE="${RADIANT_EXECUTABLE}" - ) endif () endif () @@ -323,8 +458,8 @@ 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 - COMMAND "${PROJECT_SOURCE_DIR}/gamepack-manager" --license ${GAMEPACKS_LICENSE_LIST} --name ${GAMEPACKS_NAME_LIST} --download-dir "${GAMEPACKS_DOWNLOAD_DIR}" --install-dir "${PROJECT_BINARY_DIR}" --download --install + 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 () @@ -342,36 +477,43 @@ if (BUILD_BINARIES) docs DESTINATION ${RADIANT_DATA_DIR} ) + + 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 () - - file(GLOB GAME_DIRS ${PROJECT_BINARY_DIR}/*.game) - install(DIRECTORY - ${PROJECT_BINARY_DIR}/games - ${GAME_DIRS} + ${PROJECT_BINARY_DIR}/gamepacks DESTINATION ${RADIANT_DATA_DIR} ) endif () -if(BUILD_BINARIES AND FHS_INSTALL AND NOT WIN32 AND NOT APPLE) +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 + icons/netradiant.png + DESTINATION ${RADIANT_SHARE_DIR}/pixmaps ) install(FILES - ${PROJECT_SOURCE_DIR}/icons/netradiant.desktop - DESTINATION ${CMAKE_INSTALL_PREFIX}/share/applications + icons/netradiant.desktop + DESTINATION ${RADIANT_SHARE_DIR}/applications ) install(FILES - ${PROJECT_SOURCE_DIR}/icons/mime/map.xml - DESTINATION ${CMAKE_INSTALL_PREFIX}/share/mime/model + icons/mime/map.xml + DESTINATION ${RADIANT_SHARE_DIR}/mime/model + ) +endif () + +if (APPLE) + install(DIRECTORY + setup/apple/Contents + DESTINATION ${APPLE_INSTALL_PREFIX} + ) + install(PROGRAMS + setup/apple/netradiant + DESTINATION ${APPLE_INSTALL_PREFIX}/Contents/MacOS ) endif ()