From c25b044b0eb5dc6cc4cb5f1dfed2e84b536e25e4 Mon Sep 17 00:00:00 2001 From: Bigfoot71 Date: Thu, 9 Jan 2025 15:24:24 +0100 Subject: [PATCH 1/2] fix cmake configuration issue for Android --- cmake/LibraryConfigurations.cmake | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/cmake/LibraryConfigurations.cmake b/cmake/LibraryConfigurations.cmake index fb789830683a..17287fd3e440 100644 --- a/cmake/LibraryConfigurations.cmake +++ b/cmake/LibraryConfigurations.cmake @@ -69,6 +69,16 @@ elseif (${PLATFORM} MATCHES "Android") set(CMAKE_POSITION_INDEPENDENT_CODE ON) list(APPEND raylib_sources ${ANDROID_NDK}/sources/android/native_app_glue/android_native_app_glue.c) include_directories(${ANDROID_NDK}/sources/android/native_app_glue) + + # NOTE: Here we manually remove, before adding our flags, '-Wl,--no-undefined' which is set by default and + # conflicts with '-Wl,-undefined,dynamic_lookup' that allows compilation despite the missing definition + # of 'void main(void)' which is called by raylib in `android_main()` + # We also take this opportunity to remove other problematic + # or unnecessary flags in our case. + + string(REPLACE "-Wl,--no-undefined -Qunused-arguments" "" CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS}") + string(REPLACE "-static-libstdc++" "" CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS}") + set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--exclude-libs,libatomic.a -Wl,--build-id -Wl,-z,noexecstack -Wl,-z,relro -Wl,-z,now -Wl,--warn-shared-textrel -Wl,--fatal-warnings -u ANativeActivity_onCreate -Wl,-undefined,dynamic_lookup") find_library(OPENGL_LIBRARY OpenGL) From 76212b638fb02c4e69f58951a528f56188636c3e Mon Sep 17 00:00:00 2001 From: Bigfoot71 Date: Thu, 9 Jan 2025 15:28:01 +0100 Subject: [PATCH 2/2] review comment --- cmake/LibraryConfigurations.cmake | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/cmake/LibraryConfigurations.cmake b/cmake/LibraryConfigurations.cmake index 17287fd3e440..00dda033a86a 100644 --- a/cmake/LibraryConfigurations.cmake +++ b/cmake/LibraryConfigurations.cmake @@ -70,11 +70,9 @@ elseif (${PLATFORM} MATCHES "Android") list(APPEND raylib_sources ${ANDROID_NDK}/sources/android/native_app_glue/android_native_app_glue.c) include_directories(${ANDROID_NDK}/sources/android/native_app_glue) - # NOTE: Here we manually remove, before adding our flags, '-Wl,--no-undefined' which is set by default and - # conflicts with '-Wl,-undefined,dynamic_lookup' that allows compilation despite the missing definition - # of 'void main(void)' which is called by raylib in `android_main()` - # We also take this opportunity to remove other problematic - # or unnecessary flags in our case. + # NOTE: We remove '-Wl,--no-undefined' (set by default) as it conflicts with '-Wl,-undefined,dynamic_lookup' needed + # for compiling with the missing 'void main(void)' declaration in `android_main()`. + # We also remove other unnecessary or problematic flags. string(REPLACE "-Wl,--no-undefined -Qunused-arguments" "" CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS}") string(REPLACE "-static-libstdc++" "" CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS}")