[cmake] Don't hide symbols by default (#891)
But keep use of cmake idiomatic way of making inlines hidden
This commit is contained in:
parent
584693e0cb
commit
42d3271cc3
|
@ -1,7 +1,4 @@
|
||||||
cmake_minimum_required(VERSION 2.8.0)
|
cmake_minimum_required(VERSION 2.8.0)
|
||||||
# Allow symbol hiding for both static and shared libs.
|
|
||||||
cmake_policy(SET CMP0063 NEW)
|
|
||||||
|
|
||||||
project(harfbuzz)
|
project(harfbuzz)
|
||||||
|
|
||||||
enable_testing()
|
enable_testing()
|
||||||
|
@ -528,8 +525,6 @@ endif ()
|
||||||
## Define harfbuzz library
|
## Define harfbuzz library
|
||||||
add_library(harfbuzz ${project_sources} ${project_extra_sources} ${project_headers})
|
add_library(harfbuzz ${project_sources} ${project_extra_sources} ${project_headers})
|
||||||
set_target_properties(harfbuzz PROPERTIES
|
set_target_properties(harfbuzz PROPERTIES
|
||||||
C_VISIBILITY_PRESET hidden
|
|
||||||
CXX_VISIBILITY_PRESET hidden
|
|
||||||
VISIBILITY_INLINES_HIDDEN TRUE)
|
VISIBILITY_INLINES_HIDDEN TRUE)
|
||||||
target_link_libraries(harfbuzz ${THIRD_PARTY_LIBS})
|
target_link_libraries(harfbuzz ${THIRD_PARTY_LIBS})
|
||||||
|
|
||||||
|
@ -537,8 +532,6 @@ target_link_libraries(harfbuzz ${THIRD_PARTY_LIBS})
|
||||||
add_library(harfbuzz-subset ${subset_project_sources} ${subset_project_headers})
|
add_library(harfbuzz-subset ${subset_project_sources} ${subset_project_headers})
|
||||||
add_dependencies(harfbuzz-subset harfbuzz)
|
add_dependencies(harfbuzz-subset harfbuzz)
|
||||||
set_target_properties(harfbuzz-subset PROPERTIES
|
set_target_properties(harfbuzz-subset PROPERTIES
|
||||||
C_VISIBILITY_PRESET hidden
|
|
||||||
CXX_VISIBILITY_PRESET hidden
|
|
||||||
VISIBILITY_INLINES_HIDDEN TRUE)
|
VISIBILITY_INLINES_HIDDEN TRUE)
|
||||||
target_link_libraries(harfbuzz-subset harfbuzz ${THIRD_PARTY_LIBS})
|
target_link_libraries(harfbuzz-subset harfbuzz ${THIRD_PARTY_LIBS})
|
||||||
|
|
||||||
|
@ -568,20 +561,14 @@ if (HB_HAVE_GOBJECT)
|
||||||
${hb_gobject_gen_headers}
|
${hb_gobject_gen_headers}
|
||||||
)
|
)
|
||||||
set_target_properties(harfbuzz-gobject PROPERTIES
|
set_target_properties(harfbuzz-gobject PROPERTIES
|
||||||
C_VISIBILITY_PRESET hidden
|
|
||||||
CXX_VISIBILITY_PRESET hidden
|
|
||||||
VISIBILITY_INLINES_HIDDEN TRUE)
|
VISIBILITY_INLINES_HIDDEN TRUE)
|
||||||
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR}/src)
|
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR}/src)
|
||||||
add_dependencies(harfbuzz-gobject harfbuzz)
|
add_dependencies(harfbuzz-gobject harfbuzz)
|
||||||
target_link_libraries(harfbuzz-gobject harfbuzz ${GOBJECT_LIBRARIES} ${THIRD_PARTY_LIBS})
|
target_link_libraries(harfbuzz-gobject harfbuzz ${GOBJECT_LIBRARIES} ${THIRD_PARTY_LIBS})
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
if (BUILD_SHARED_LIBS)
|
if (BUILD_SHARED_LIBS AND WIN32 AND NOT MINGW)
|
||||||
if (WIN32 AND NOT MINGW)
|
add_definitions("-DHB_EXTERN=__declspec(dllexport) extern")
|
||||||
add_definitions("-DHB_EXTERN=__declspec(dllexport) extern")
|
|
||||||
else ()
|
|
||||||
add_definitions("-DHB_EXTERN=__attribute__(( visibility( \"default\" ) )) extern")
|
|
||||||
endif ()
|
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
# On Windows, g-ir-scanner requires a DLL build in order for it to work
|
# On Windows, g-ir-scanner requires a DLL build in order for it to work
|
||||||
|
|
Loading…
Reference in New Issue