Skip to content

Commit c720204

Browse files
Fix BUILD_SHARED_LIBS issue (#1496)
1 parent 294db69 commit c720204

File tree

3 files changed

+12
-17
lines changed

3 files changed

+12
-17
lines changed

CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -84,6 +84,7 @@ set(CMAKE_CXX_STANDARD_REQUIRED TRUE)
8484
set(CMAKE_CXX_EXTENSIONS FALSE)
8585

8686
#BEGIN internal
87+
option(BUILD_SHARED_LIBS "Use \"ON\" to build shared libraries instead of static where it's not specified (not recommended)" OFF)
8788
option(USE_EMSCRIPTEN "Use \"ON\" for config building wasm." OFF)
8889
option(TON_ONLY_TONLIB "Use \"ON\" to build only tonlib." OFF)
8990
if (USE_EMSCRIPTEN)

emulator/CMakeLists.txt

+6-10
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,5 @@
11
cmake_minimum_required(VERSION 3.5 FATAL_ERROR)
22

3-
option(BUILD_SHARED_LIBS "Use \"OFF\" for a static build." ON)
4-
53
if (NOT OPENSSL_FOUND)
64
find_package(OpenSSL REQUIRED)
75
endif()
@@ -11,11 +9,6 @@ set(EMULATOR_STATIC_SOURCE
119
tvm-emulator.hpp
1210
)
1311

14-
set(EMULATOR_HEADERS
15-
transaction-emulator.h
16-
emulator-extern.h
17-
)
18-
1912
set(EMULATOR_SOURCE
2013
emulator-extern.cpp
2114
)
@@ -29,10 +22,10 @@ include(GenerateExportHeader)
2922
add_library(emulator_static STATIC ${EMULATOR_STATIC_SOURCE})
3023
target_link_libraries(emulator_static PUBLIC ton_crypto smc-envelope)
3124

32-
if (NOT USE_EMSCRIPTEN AND BUILD_SHARED_LIBS)
33-
add_library(emulator SHARED ${EMULATOR_SOURCE} ${EMULATOR_HEADERS})
25+
if (USE_EMSCRIPTEN)
26+
add_library(emulator STATIC ${EMULATOR_SOURCE})
3427
else()
35-
add_library(emulator STATIC ${EMULATOR_SOURCE} ${EMULATOR_HEADERS})
28+
add_library(emulator SHARED ${EMULATOR_SOURCE})
3629
endif()
3730

3831
if (PORTABLE AND NOT APPLE)
@@ -42,6 +35,9 @@ else()
4235
endif()
4336

4437
generate_export_header(emulator EXPORT_FILE_NAME ${CMAKE_CURRENT_BINARY_DIR}/emulator_export.h)
38+
if (USE_EMSCRIPTEN)
39+
target_compile_definitions(emulator PUBLIC EMULATOR_STATIC_DEFINE)
40+
endif()
4541
target_include_directories(emulator PUBLIC
4642
$<BUILD_INTERFACE:${CMAKE_CURRENT_BINARY_DIR}>
4743
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}>)

tonlib/CMakeLists.txt

+5-7
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,5 @@
11
cmake_minimum_required(VERSION 3.5 FATAL_ERROR)
22

3-
option(BUILD_SHARED_LIBS "Use \"OFF\" for a static build." ON)
4-
53
if (NOT OPENSSL_FOUND)
64
find_package(OpenSSL REQUIRED)
75
endif()
@@ -92,10 +90,10 @@ set(TONLIB_JSON_HEADERS tonlib/tonlib_client_json.h)
9290
set(TONLIB_JSON_SOURCE tonlib/tonlib_client_json.cpp)
9391

9492
include(GenerateExportHeader)
95-
if (NOT USE_EMSCRIPTEN AND BUILD_SHARED_LIBS)
96-
add_library(tonlibjson SHARED ${TONLIB_JSON_SOURCE} ${TONLIB_JSON_HEADERS})
93+
if (USE_EMSCRIPTEN)
94+
add_library(tonlibjson STATIC ${TONLIB_JSON_SOURCE})
9795
else()
98-
add_library(tonlibjson STATIC ${TONLIB_JSON_SOURCE} ${TONLIB_JSON_HEADERS})
96+
add_library(tonlibjson SHARED ${TONLIB_JSON_SOURCE})
9997
endif()
10098

10199
if (PORTABLE AND NOT APPLE)
@@ -105,7 +103,7 @@ else()
105103
endif()
106104

107105
generate_export_header(tonlibjson EXPORT_FILE_NAME ${CMAKE_CURRENT_BINARY_DIR}/tonlib/tonlibjson_export.h)
108-
if (!BUILD_SHARED_LIBS)
106+
if (USE_EMSCRIPTEN)
109107
target_compile_definitions(tonlibjson PUBLIC TONLIBJSON_STATIC_DEFINE)
110108
endif()
111109
target_include_directories(tonlibjson PUBLIC
@@ -159,7 +157,7 @@ endif()
159157

160158
install(FILES ${TONLIB_JSON_HEADERS} ${CMAKE_CURRENT_BINARY_DIR}/tonlib/tonlibjson_export.h DESTINATION include/tonlib/)
161159

162-
if (NOT USE_EMSCRIPTEN AND BUILD_SHARED_LIBS)
160+
if (NOT USE_EMSCRIPTEN)
163161
install(EXPORT Tonlib
164162
FILE TonlibTargets.cmake
165163
NAMESPACE Tonlib::

0 commit comments

Comments
 (0)