Skip to content

Commit ef49a11

Browse files
committed
build: allow static or shared but not both
1 parent 36b0adf commit ef49a11

File tree

3 files changed

+53
-71
lines changed

3 files changed

+53
-71
lines changed

CMakeLists.txt

+11-7
Original file line numberDiff line numberDiff line change
@@ -26,11 +26,10 @@ set(CMAKE_C_EXTENSIONS OFF)
2626

2727
list(APPEND CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/cmake)
2828

29-
# We do not use CMake's BUILD_SHARED_LIBS option.
30-
option(SECP256K1_BUILD_SHARED "Build shared library." ON)
31-
option(SECP256K1_BUILD_STATIC "Build static library." ON)
32-
if(NOT SECP256K1_BUILD_SHARED AND NOT SECP256K1_BUILD_STATIC)
33-
message(FATAL_ERROR "At least one of SECP256K1_BUILD_SHARED and SECP256K1_BUILD_STATIC must be enabled.")
29+
option(BUILD_SHARED_LIBS "Build shared libraries" ON)
30+
option(SECP256K1_DISABLE_SHARED "Disable shared library. Overrides BUILD_SHARED_LIBS." OFF)
31+
if(SECP256K1_DISABLE_SHARED)
32+
set(BUILD_SHARED_LIBS OFF)
3433
endif()
3534

3635
option(SECP256K1_ENABLE_MODULE_ECDH "Enable ECDH module." ON)
@@ -225,8 +224,13 @@ message("\n")
225224
message("secp256k1 configure summary")
226225
message("===========================")
227226
message("Build artifacts:")
228-
message(" shared library ...................... ${SECP256K1_BUILD_SHARED}")
229-
message(" static library ...................... ${SECP256K1_BUILD_STATIC}")
227+
if(BUILD_SHARED_LIBS)
228+
set(library_type "Shared")
229+
else()
230+
set(library_type "Static")
231+
endif()
232+
233+
message(" library type ........................ ${library_type}")
230234
message("Optional modules:")
231235
message(" ECDH ................................ ${SECP256K1_ENABLE_MODULE_ECDH}")
232236
message(" ECDSA pubkey recovery ............... ${SECP256K1_ENABLE_MODULE_RECOVERY}")

examples/CMakeLists.txt

+3-7
Original file line numberDiff line numberDiff line change
@@ -6,15 +6,11 @@ target_compile_options(example INTERFACE
66
$<$<C_COMPILER_ID:MSVC>:/wd4005>
77
)
88
target_link_libraries(example INTERFACE
9+
secp256k1
910
$<$<PLATFORM_ID:Windows>:bcrypt>
1011
)
11-
if(SECP256K1_BUILD_SHARED)
12-
target_link_libraries(example INTERFACE secp256k1)
13-
elseif(SECP256K1_BUILD_STATIC)
14-
target_link_libraries(example INTERFACE secp256k1_static)
15-
if(MSVC)
16-
target_link_options(example INTERFACE /IGNORE:4217)
17-
endif()
12+
if(NOT BUILD_SHARED_LIBS AND MSVC)
13+
target_link_options(example INTERFACE /IGNORE:4217)
1814
endif()
1915

2016
add_executable(ecdsa_example ecdsa.c)

src/CMakeLists.txt

+39-57
Original file line numberDiff line numberDiff line change
@@ -1,97 +1,79 @@
11
# Must be included before CMAKE_INSTALL_INCLUDEDIR is used.
22
include(GNUInstallDirs)
3-
set(${PROJECT_NAME}_installables "")
43

4+
add_library(secp256k1_precomputed OBJECT EXCLUDE_FROM_ALL
5+
precomputed_ecmult.c
6+
precomputed_ecmult_gen.c
7+
)
8+
9+
# Add objects explicitly rather than linking to the object libs to keep them
10+
# from being exported.
11+
add_library(secp256k1 secp256k1.c $<TARGET_OBJECTS:secp256k1_precomputed>)
12+
13+
add_library(secp256k1_asm INTERFACE)
514
if(SECP256K1_ASM STREQUAL "arm")
6-
add_library(common OBJECT
15+
add_library(secp256k1_asm_arm OBJECT EXCLUDE_FROM_ALL)
16+
target_sources(secp256k1_asm_arm PUBLIC
717
asm/field_10x26_arm.s
818
)
9-
set(common_obj "$<TARGET_OBJECTS:common>")
10-
else()
11-
set(common_obj "")
19+
target_sources(secp256k1 PRIVATE $<TARGET_OBJECTS:secp256k1_asm_arm>)
20+
target_link_libraries(secp256k1_asm INTERFACE secp256k1_asm_arm)
1221
endif()
1322

14-
add_library(precomputed OBJECT
15-
precomputed_ecmult.c
16-
precomputed_ecmult_gen.c
17-
)
18-
set(internal_obj "$<TARGET_OBJECTS:precomputed>" "${common_obj}")
23+
# Define our export symbol only for Win32 and only for shared libs.
24+
# This matches libtool's usage of DLL_EXPORT
25+
if(WIN32)
26+
set_target_properties(secp256k1 PROPERTIES DEFINE_SYMBOL "DLL_EXPORT")
27+
endif()
1928

20-
add_library(secp256k1 SHARED EXCLUDE_FROM_ALL
21-
secp256k1.c
22-
${internal_obj}
23-
)
24-
target_include_directories(secp256k1 INTERFACE
29+
# Object libs don't know if they're being built for a shared or static lib.
30+
# Grab the PIC property from secp256k1 which knows.
31+
get_target_property(use_pic secp256k1 POSITION_INDEPENDENT_CODE)
32+
set_target_properties(secp256k1_precomputed PROPERTIES POSITION_INDEPENDENT_CODE ${use_pic})
33+
34+
target_include_directories(secp256k1 PUBLIC
2535
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>
2636
)
27-
target_compile_definitions(secp256k1 PRIVATE
28-
$<$<PLATFORM_ID:Windows>:DLL_EXPORT>
29-
)
3037
set_target_properties(secp256k1 PROPERTIES
3138
VERSION "${${PROJECT_NAME}_LIB_VERSION_CURRENT}.${${PROJECT_NAME}_LIB_VERSION_AGE}.${${PROJECT_NAME}_LIB_VERSION_REVISION}"
3239
SOVERSION "${${PROJECT_NAME}_LIB_VERSION_CURRENT}"
3340
)
34-
if(SECP256K1_BUILD_SHARED)
35-
get_target_property(use_pic secp256k1 POSITION_INDEPENDENT_CODE)
36-
set_target_properties(precomputed PROPERTIES POSITION_INDEPENDENT_CODE ${use_pic})
37-
set_target_properties(secp256k1 PROPERTIES EXCLUDE_FROM_ALL FALSE)
38-
list(APPEND ${PROJECT_NAME}_installables secp256k1)
39-
endif()
40-
41-
add_library(secp256k1_static STATIC EXCLUDE_FROM_ALL
42-
secp256k1.c
43-
${internal_obj}
44-
)
45-
target_include_directories(secp256k1_static INTERFACE
46-
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>
47-
)
48-
if(NOT MSVC)
49-
set_target_properties(secp256k1_static PROPERTIES
50-
OUTPUT_NAME secp256k1
51-
)
52-
endif()
53-
if(SECP256K1_BUILD_STATIC)
54-
set_target_properties(secp256k1_static PROPERTIES EXCLUDE_FROM_ALL FALSE)
55-
list(APPEND ${PROJECT_NAME}_installables secp256k1_static)
56-
endif()
57-
58-
add_library(link_library INTERFACE)
59-
if(SECP256K1_BUILD_SHARED)
60-
target_link_libraries(link_library INTERFACE secp256k1)
61-
elseif(SECP256K1_BUILD_STATIC)
62-
target_link_libraries(link_library INTERFACE secp256k1_static)
63-
endif()
6441

6542
if(SECP256K1_BUILD_BENCHMARK)
6643
add_executable(bench bench.c)
67-
target_link_libraries(bench link_library)
68-
add_executable(bench_internal bench_internal.c ${internal_obj})
69-
add_executable(bench_ecmult bench_ecmult.c ${internal_obj})
44+
target_link_libraries(bench secp256k1)
45+
add_executable(bench_internal bench_internal.c)
46+
target_link_libraries(bench_internal secp256k1_precomputed secp256k1_asm)
47+
add_executable(bench_ecmult bench_ecmult.c)
48+
target_link_libraries(bench_ecmult secp256k1_precomputed secp256k1_asm)
7049
endif()
7150

7251
if(SECP256K1_BUILD_TESTS)
73-
add_executable(noverify_tests tests.c ${internal_obj})
52+
add_executable(noverify_tests tests.c)
53+
target_link_libraries(noverify_tests secp256k1_precomputed secp256k1_asm)
7454
add_test(noverify_tests noverify_tests)
7555
if(NOT CMAKE_BUILD_TYPE STREQUAL "Coverage")
76-
add_executable(tests tests.c ${internal_obj})
56+
add_executable(tests tests.c)
7757
target_compile_definitions(tests PRIVATE VERIFY)
58+
target_link_libraries(tests secp256k1_precomputed secp256k1_asm)
7859
add_test(tests tests)
7960
endif()
8061
endif()
8162

8263
if(SECP256K1_BUILD_EXHAUSTIVE_TESTS)
83-
# Note: do not include $<TARGET_OBJECTS:precomputed> in exhaustive_tests (it uses runtime-generated tables).
84-
add_executable(exhaustive_tests tests_exhaustive.c ${common_obj})
64+
# Note: do not include secp256k1_precomputed in exhaustive_tests (it uses runtime-generated tables).
65+
add_executable(exhaustive_tests tests_exhaustive.c)
66+
target_link_libraries(exhaustive_tests secp256k1_asm)
8567
target_compile_definitions(exhaustive_tests PRIVATE $<$<NOT:$<CONFIG:Coverage>>:VERIFY>)
8668
add_test(exhaustive_tests exhaustive_tests)
8769
endif()
8870

8971
if(SECP256K1_BUILD_CTIME_TESTS)
9072
add_executable(ctime_tests ctime_tests.c)
91-
target_link_libraries(ctime_tests link_library)
73+
target_link_libraries(ctime_tests secp256k1)
9274
endif()
9375

94-
install(TARGETS ${${PROJECT_NAME}_installables}
76+
install(TARGETS secp256k1
9577
EXPORT ${PROJECT_NAME}-targets
9678
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
9779
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}

0 commit comments

Comments
 (0)