X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=CMakeLists.txt;h=cfef0a021a2f9ff338c89a4d5fbf93ec8669405c;hb=455026606be8472bd8f349124aeb5e06624d986d;hp=b17ed2b197f3b8956387ac8ffb7f1fa2ac0526a3;hpb=e050a83cd52858eb64e2750ac440c9c554e2367c;p=xonotic%2Fnetradiant.git diff --git a/CMakeLists.txt b/CMakeLists.txt index b17ed2b1..cfef0a02 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -12,6 +12,12 @@ set(BUILTINS_LIB_DIR "${BUILTINS_INSTALL_DIR}/lib") set(BUILTINS_PKGCONFIG_DIR "${BUILTINS_INSTALL_DIR}/lib/pkgconfig") option(BUILTIN_GTKGLEXT "Builtin GtkGLExt" OFF) +option(BUILTIN_GTKTHEME_MOJAVE "Builtin Mojave GTK theme" OFF) + +if (APPLE) + set(BUILTIN_GTKGLEXT ON) + set(BUILTIN_GTKTHEME_MOJAVE ON) +endif () set(BUILTIN_GTKGLEXT_BUILT OFF CACHE INTERNAL "...") if (EXISTS "${BUILTINS_INSTALL_DIR}/lib/pkgconfig/gtkglext-1.0.pc") @@ -71,7 +77,9 @@ if (BUILD_RADIANT OR BUILD_TOOLS) endif () if (BUILD_BINARIES) - if (WIN32 OR APPLE OR "${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") + if (WIN32 OR APPLE + OR "${CMAKE_SYSTEM_NAME}" STREQUAL "Linux" + OR "${CMAKE_SYSTEM_NAME}" STREQUAL "FreeBSD" ) set(BUNDLING_SUPPORTED ON) endif() @@ -99,10 +107,10 @@ if (CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) endif () if (APPLE) - set(APPLE_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX}/NetRadiant.app) - set(FINAL_INSTALL_PREFIX ${APPLE_INSTALL_PREFIX}/Contents/Prefix) + 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}) + set(FINAL_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX}) endif () set(RADIANT_NAME "NetRadiant" CACHE INTERNAL "...") @@ -221,6 +229,10 @@ if (BUILD_BINARIES) addflags("-Wno-unused-variable") addflags("-Wno-unused-parameter") + if (APPLE) + add_definitions(-DGL_SILENCE_DEPRECATION=1) + endif() + set(CMAKE_POSITION_INDEPENDENT_CODE 1) endif () @@ -239,6 +251,7 @@ if (BUILD_RADIANT) if (APPLE) if (GTK_TARGET EQUAL 2) add_definitions(-DWORKAROUND_MACOS_GTK2_DESTROY=1) + add_definitions(-DWORKAROUND_MACOS_GTK2_GLWIDGET=1) endif () endif () endif () @@ -334,9 +347,11 @@ endif () add_custom_target(builtins) -if (BUILTIN_GTKGLEXT) +if (BUILTIN_GTKGLEXT OR BUILTIN_GTKTHEME_MOJAVE) include(${CMAKE_ROOT}/Modules/ExternalProject.cmake) +endif () +if (BUILTIN_GTKGLEXT) execute_process(COMMAND pkg-config --libs gdk-2.0 gtk+-2.0 glib-2.0 gl OUTPUT_VARIABLE GTKGLEXT_LDFLAGS OUTPUT_STRIP_TRAILING_WHITESPACE @@ -344,15 +359,16 @@ if (BUILTIN_GTKGLEXT) 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(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) + set(GTKGLEXT_CFLAGS "${GTKGLEXT_CFLAGS} -DGL_SILENCE_DEPRECATION=1") else () set(GTKGLEXT_GIT_TAG fixes) endif () @@ -375,10 +391,27 @@ if (BUILTIN_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) +if (BUNDLE_LIBRARIES) + # It was required to tell cmake to not patch rpath on macos builtins. + # It was also required to tell cmake to not patch rpath on freebsd binaries. + # Patching rpath is done in library_bundler instead so we can skip this + # step entirely when bundling. + set(CMAKE_SKIP_RPATH ON) endif() +if (BUILTIN_GTKTHEME_MOJAVE) + ExternalProject_Add(gtktheme-mojave + GIT_REPOSITORY https://github.com/vinceliuice/Mojave-gtk-theme.git + GIT_TAG master + BUILD_IN_SOURCE ON + CONFIGURE_COMMAND echo + BUILD_COMMAND echo + INSTALL_COMMAND ./install.sh -o standard -a standard -s standard -i standard -d "${PROJECT_BINARY_DIR}/themes" + ) + add_dependencies(builtins gtktheme-mojave) + set_target_properties(gtktheme-mojave PROPERTIES EXCLUDE_FROM_ALL ON) +endif () + #----------------------------------------------------------------------- # Libraries #----------------------------------------------------------------------- @@ -493,26 +526,30 @@ endif () if (BUILD_BINARIES AND FHS_INSTALL AND NOT WIN32 AND NOT APPLE) install(FILES - ${PROJECT_SOURCE_DIR}/icons/netradiant.png + icons/netradiant.png DESTINATION ${RADIANT_SHARE_DIR}/pixmaps ) install(FILES - ${PROJECT_SOURCE_DIR}/icons/netradiant.desktop + icons/netradiant.desktop DESTINATION ${RADIANT_SHARE_DIR}/applications ) install(FILES - ${PROJECT_SOURCE_DIR}/icons/mime/map.xml + icons/mime/map.xml DESTINATION ${RADIANT_SHARE_DIR}/mime/model ) endif () if (APPLE) install(DIRECTORY - setup/apple/Contents + setup/macos/Contents DESTINATION ${APPLE_INSTALL_PREFIX} ) + install(DIRECTORY + ${PROJECT_BINARY_DIR}/themes + DESTINATION ${APPLE_INSTALL_PREFIX}/Contents/Prefix/share + ) install(PROGRAMS - setup/apple/netradiant + setup/macos/NetRadiant DESTINATION ${APPLE_INSTALL_PREFIX}/Contents/MacOS ) endif ()