@@ -54,27 +54,16 @@ add_library(secp256k1_precomputed OBJECT EXCLUDE_FROM_ALL
5454# from being exported.
5555target_sources (secp256k1 PRIVATE secp256k1.c $<TARGET_OBJECTS:secp256k1_precomputed>)
5656
57- # Create a helper lib that parent projects can use to link secp256k1 into a
58- # static lib.
59- add_library (secp256k1_objs INTERFACE )
60- target_sources (secp256k1_objs INTERFACE $<TARGET_OBJECTS:secp256k1> $<TARGET_OBJECTS:secp256k1_precomputed>)
61-
62- add_library (secp256k1_asm INTERFACE )
6357if (SECP256K1_ASM STREQUAL "arm32" )
64- add_library (secp256k1_asm_arm OBJECT EXCLUDE_FROM_ALL )
65- target_sources (secp256k1_asm_arm PUBLIC
66- asm/field_10x26_arm.s
67- )
68- target_sources (secp256k1 PRIVATE $<TARGET_OBJECTS:secp256k1_asm_arm>)
69- target_sources (secp256k1_objs INTERFACE $<TARGET_OBJECTS:secp256k1_asm_arm>)
70- target_link_libraries (secp256k1_asm INTERFACE secp256k1_asm_arm)
58+ add_library (secp256k1_asm OBJECT EXCLUDE_FROM_ALL asm/field_10x26_arm.s)
59+ else ()
60+ add_library (secp256k1_asm INTERFACE )
7161endif ()
7262
73- if (WIN32 )
74- # Define our export symbol only for shared libs.
75- set_target_properties (secp256k1 PROPERTIES DEFINE_SYMBOL SECP256K1_DLL_EXPORT)
76- target_compile_definitions (secp256k1 INTERFACE $<$<NOT :$<BOOL :${BUILD_SHARED_LIBS} >>:SECP256K1_STATIC>)
77- endif ()
63+ # When building a static libary, SECP256K1_STATIC must be defined both for itself and downstream.
64+ # Note that the generator expression is evaluated in the context of the consuming target!
65+ target_compile_definitions (secp256k1 PUBLIC $<$<STREQUAL :$<TARGET_PROPERTY:secp256k1,TYPE >,STATIC_LIBRARY>:SECP256K1_STATIC>)
66+ set_target_properties (secp256k1 PROPERTIES C_VISIBILITY_PRESET hidden VISIBILITY_INLINES_HIDDEN ON )
7867
7968# Object libs don't know if they're being built for a shared or static lib.
8069# Grab the PIC property from secp256k1 which knows.
@@ -85,9 +74,6 @@ set_target_properties(secp256k1_precomputed PROPERTIES POSITION_INDEPENDENT_CODE
8574target_include_directories (secp256k1 INTERFACE
8675 $<BUILD_INTERFACE:$<$<NOT :$<BOOL :${PROJECT_IS_TOP_LEVEL} >>:${PROJECT_SOURCE_DIR} /include >>
8776)
88- set_target_properties (secp256k1_objs PROPERTIES
89- INTERFACE_INCLUDE_DIRECTORIES "$<TARGET_PROPERTY:secp256k1,INTERFACE_INCLUDE_DIRECTORIES>"
90- )
9177
9278# This emulates Libtool to make sure Libtool and CMake agree on the ABI version,
9379# see below "Calculate the version variables" in build-aux/ltmain.sh.
@@ -123,18 +109,21 @@ if(SECP256K1_BUILD_BENCHMARK)
123109 add_executable (bench bench.c)
124110 target_link_libraries (bench secp256k1)
125111 add_executable (bench_internal bench_internal.c)
112+ target_compile_definitions (bench_internal PRIVATE $<TARGET_PROPERTY:secp256k1,INTERFACE_COMPILE_DEFINITIONS >)
126113 target_link_libraries (bench_internal secp256k1_precomputed secp256k1_asm)
127114 add_executable (bench_ecmult bench_ecmult.c)
115+ target_compile_definitions (bench_ecmult PRIVATE $<TARGET_PROPERTY:secp256k1,INTERFACE_COMPILE_DEFINITIONS >)
128116 target_link_libraries (bench_ecmult secp256k1_precomputed secp256k1_asm)
129117endif ()
130118
131119if (SECP256K1_BUILD_TESTS)
132120 add_executable (noverify_tests tests.c)
121+ target_compile_definitions (noverify_tests PRIVATE $<TARGET_PROPERTY:secp256k1,INTERFACE_COMPILE_DEFINITIONS >)
133122 target_link_libraries (noverify_tests secp256k1_precomputed secp256k1_asm)
134123 add_test (NAME secp256k1_noverify_tests COMMAND noverify_tests)
135124 if (NOT CMAKE_BUILD_TYPE STREQUAL "Coverage" )
136125 add_executable (tests tests.c)
137- target_compile_definitions (tests PRIVATE VERIFY)
126+ target_compile_definitions (tests PRIVATE VERIFY $<TARGET_PROPERTY:secp256k1, INTERFACE_COMPILE_DEFINITIONS > )
138127 target_link_libraries (tests secp256k1_precomputed secp256k1_asm)
139128 add_test (NAME secp256k1_tests COMMAND tests)
140129 endif ()
@@ -144,7 +133,10 @@ if(SECP256K1_BUILD_EXHAUSTIVE_TESTS)
144133 # Note: do not include secp256k1_precomputed in exhaustive_tests (it uses runtime-generated tables).
145134 add_executable (exhaustive_tests tests_exhaustive.c)
146135 target_link_libraries (exhaustive_tests secp256k1_asm)
147- target_compile_definitions (exhaustive_tests PRIVATE $<$<NOT :$<CONFIG:Coverage>>:VERIFY>)
136+ target_compile_definitions (exhaustive_tests PRIVATE
137+ $<$<NOT :$<CONFIG:Coverage>>:VERIFY>
138+ $<TARGET_PROPERTY:secp256k1,INTERFACE_COMPILE_DEFINITIONS >
139+ )
148140 add_test (NAME secp256k1_exhaustive_tests COMMAND exhaustive_tests)
149141endif ()
150142
0 commit comments