X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=CMakeLists.txt;h=b2fa296e953cd9c6c2fcfec248b5a3afd8bd3ab1;hb=1f52ad57d11ab6661f6166b83f8d0f02ee626d57;hp=b01730e8fcd1690b2d081fefb019385719e6d542;hpb=f80fb44b67d748419a38cb864eeb615ed83f6963;p=xonotic%2Fnetradiant.git diff --git a/CMakeLists.txt b/CMakeLists.txt index b01730e8..b2fa296e 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -15,12 +15,12 @@ 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) + 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") +if (EXISTS "${BUILTINS_PKGCONFIG_DIR}gtkglext-1.0.pc") set(BUILTIN_GTKGLEXT_BUILT ON) endif () @@ -77,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() @@ -105,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 "...") @@ -227,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 () @@ -246,6 +252,7 @@ if (BUILD_RADIANT) if (GTK_TARGET EQUAL 2) add_definitions(-DWORKAROUND_MACOS_GTK2_DESTROY=1) add_definitions(-DWORKAROUND_MACOS_GTK2_GLWIDGET=1) + add_definitions(-DWORKAROUND_MACOS_GTK2_LAGGYPOINTER=1) endif () endif () endif () @@ -346,17 +353,29 @@ if (BUILTIN_GTKGLEXT OR BUILTIN_GTKTHEME_MOJAVE) endif () if (BUILTIN_GTKGLEXT) - execute_process(COMMAND pkg-config --libs gdk-2.0 gtk+-2.0 glib-2.0 gl + set(GTKGLEXT_PKGNAMES "gdk-2.0 gtk+-2.0 glib-2.0") + + if (NOT APPLE) + set(GTKGLEXT_PKGNAMES "${GTKGLEXT_PKGNAMES} gl") + endif () + + execute_process(COMMAND pkg-config --libs ${GTKGLEXT_PKGNAMES} OUTPUT_VARIABLE GTKGLEXT_LDFLAGS OUTPUT_STRIP_TRAILING_WHITESPACE ) + set(GTKGLEXT_LDFLAGS "$ENV{LDFLAGS} -lm ${GTKGLEXT_LDFLAGS}") + execute_process(COMMAND pkg-config --cflags ${GTKGLEXT_PKGNAMES} + OUTPUT_VARIABLE GTKGLEXT_CFLAGS + OUTPUT_STRIP_TRAILING_WHITESPACE + ) + + set(GTKGLEXT_CFLAGS "$ENV{CFLAGS} ${GTKGLEXT_CFLAGS}") + if (NOT CMAKE_BUILD_TYPE MATCHES Release) - set(GTKGLEXT_CFLAGS "$ENV{CFLAGS} -g") - else () - set(GTKGLEXT_CFLAGS "$ENV{CFLAGS}") - endif() + set(GTKGLEXT_CFLAGS "${GTKGLEXT_CFLAGS} -g") + endif () set(CONFIGURE_OPTIONS --disable-gtk-doc --disable-gtk-doc-html --disable-gtk-doc-pdf) @@ -366,30 +385,44 @@ if (BUILTIN_GTKGLEXT) set(GTKGLEXT_GIT_TAG fixes) endif () + if (APPLE) + set(GTKGLEXT_CFLAGS "${GTKGLEXT_CFLAGS} -DGL_SILENCE_DEPRECATION=1") + # FIXME: OpenGL deprecation warnings are not silenced + # in Objective C code. + 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 export CFLAGS=${GTKGLEXT_LDFLAGS} + CONFIGURE_COMMAND && export LDFLAGS=${GTKGLEXT_CFLAGS} + CONFIGURE_COMMAND && export NOCONFIGURE=1 + CONFIGURE_COMMAND && ./autogen.sh CONFIGURE_COMMAND && ./configure --prefix "${BUILTINS_INSTALL_DIR}" ${CONFIGURE_OPTIONS} - BUILD_COMMAND $(MAKE) CFLAGS=${GTKGLEXT_CFLAGS} LDFLAGS=${GTKGLEXT_LDFLAGS} + BUILD_COMMAND $(MAKE) + BUILD_COMMAND CFLAGS=${GTKGLEXT_CFLAGS} + BUILD_COMMAND 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") + include_directories("${BUILTINS_INCLUDE_DIR}/gtkglext-1.0") + include_directories("${BUILTINS_LIB_DIR}/gtkglext-1.0/include") 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) +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 + ExternalProject_Add(gtktheme-mojave GIT_REPOSITORY https://github.com/vinceliuice/Mojave-gtk-theme.git GIT_TAG master BUILD_IN_SOURCE ON