From 8c3c05082ea176bbd339b0948aa7797a94e0de2c Mon Sep 17 00:00:00 2001 From: Alex Melman Date: Fri, 14 Jan 2022 18:19:13 +0200 Subject: [PATCH 1/4] wextra only for gcc --- CMakeLists.txt | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index a97a9c960..534b8cbac 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -285,7 +285,11 @@ endif() if (NOT MSVC) add_cxx_compiler_flag("-Wall") endif() -add_cxx_compiler_flag("-Wextra") + +if(CMAKE_COMPILER_IS_GNUCXX) + add_cxx_compiler_flag("-Wextra") +endif(CMAKE_COMPILER_IS_GNUCXX) + add_cxx_compiler_flag("-Wimplicit-fallthrough=2") add_cxx_compiler_flag("-Wpointer-arith") add_cxx_compiler_flag("-Wcast-qual") From e9777e8697f4abf9762882a5d550bfe49ea89873 Mon Sep 17 00:00:00 2001 From: Alex Melman Date: Sat, 15 Jan 2022 18:56:38 +0200 Subject: [PATCH 2/4] adjust java include path --- CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 534b8cbac..99b58ebbd 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -287,7 +287,7 @@ if (NOT MSVC) endif() if(CMAKE_COMPILER_IS_GNUCXX) - add_cxx_compiler_flag("-Wextra") + add_cxx_compiler_flag("-Wextra") endif(CMAKE_COMPILER_IS_GNUCXX) add_cxx_compiler_flag("-Wimplicit-fallthrough=2") From 8cd9d3b65942a87d45b42ff61eff636e48f9183a Mon Sep 17 00:00:00 2001 From: Alex Melman Date: Sat, 15 Jan 2022 18:59:01 +0200 Subject: [PATCH 3/4] if not msvc --- CMakeLists.txt | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 99b58ebbd..ae71905b0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -284,11 +284,8 @@ if (MSVC) endif() if (NOT MSVC) add_cxx_compiler_flag("-Wall") -endif() - -if(CMAKE_COMPILER_IS_GNUCXX) add_cxx_compiler_flag("-Wextra") -endif(CMAKE_COMPILER_IS_GNUCXX) +endif() add_cxx_compiler_flag("-Wimplicit-fallthrough=2") add_cxx_compiler_flag("-Wpointer-arith") From 7b5c2c0babec3dd73e86ce331c9f5eaf045c34da Mon Sep 17 00:00:00 2001 From: Alex Melman Date: Sun, 16 Jan 2022 10:30:43 +0200 Subject: [PATCH 4/4] Include windows condition --- example/android/CMakeLists.txt | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/example/android/CMakeLists.txt b/example/android/CMakeLists.txt index 06454852b..34d6051c5 100644 --- a/example/android/CMakeLists.txt +++ b/example/android/CMakeLists.txt @@ -7,9 +7,14 @@ cmake_minimum_required(VERSION 3.4.1 FATAL_ERROR) option(TONLIB_ENABLE_JNI "Enable JNI-compatible TonLib API" ON) -string(APPEND CMAKE_CXX_FLAGS " -std=c++14 -Wall -Wextra -Wno-unused-parameter -Wno-deprecated-declarations -Wconversion -Wno-sign-conversion -fno-omit-frame-pointer -ffunction-sections -fdata-sections") -string(APPEND CMAKE_SHARED_LINKER_FLAGS " -Wl,--gc-sections -Wl,--exclude-libs,ALL") - +if (${CMAKE_SYSTEM_NAME} MATCHES "Windows") + string(APPEND CMAKE_CXX_FLAGS " -std=c++14 -fno-omit-frame-pointer -ffunction-sections -fdata-sections") +else() + string(APPEND CMAKE_CXX_FLAGS " -std=c++14 -Wall -Wextra -Wno-unused-parameter -Wno-deprecated-declarations -Wconversion -Wno-sign-conversion -fno-omit-frame-pointer -ffunction-sections -fdata-sections") +endif() +if (NOT ${CMAKE_SYSTEM_NAME} MATCHES "Darwin") + string(APPEND CMAKE_SHARED_LINKER_FLAGS " -Wl,--gc-sections -Wl,--exclude-libs,ALL") +endif() # Creates and names a library, sets it as either STATIC # or SHARED, and provides the relative paths to its source code. # You can define multiple libraries, and CMake builds them for you. @@ -37,9 +42,15 @@ target_link_libraries(native-lib tonlib) set(TONLIB_API_JAVA_PACKAGE "drinkless/org/ton") target_compile_definitions(native-lib PRIVATE PACKAGE_NAME="${TONLIB_API_JAVA_PACKAGE}") -add_custom_command(TARGET native-lib POST_BUILD - COMMAND ${CMAKE_COMMAND} -E rename $ $.debug - COMMAND ${CMAKE_STRIP} --strip-debug --strip-unneeded $.debug -o $) +if (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") + add_custom_command(TARGET native-lib POST_BUILD + COMMAND ${CMAKE_COMMAND} -E rename $ $.debug + COMMAND ${CMAKE_STRIP} -S $.debug -o $) +elseif (${CMAKE_SYSTEM_NAME} MATCHES "Linux") + add_custom_command(TARGET native-lib POST_BUILD + COMMAND ${CMAKE_COMMAND} -E rename $ $.debug + COMMAND ${CMAKE_STRIP} --strip-debug --strip-unneeded $.debug -o $) +endif() if (NOT CMAKE_CROSSCOMPILING) set(TONLIB_API_JAVA_PATH ${CMAKE_CURRENT_SOURCE_DIR}/src/)