From ac533e18db2c8952255f89449ee278d876d20785 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Fri, 29 Jun 2018 08:45:27 +0800 Subject: [CMake] Implement absl_cc_library as Bazel's cc_library cc_library --- CMake/AbseilHelpers.cmake | 107 ++++++++++++++++++++++++++++++++++ absl/base/CMakeLists.txt | 31 ++++------ absl/strings/CMakeLists.txt | 136 +++++++++++++++++++------------------------- 3 files changed, 179 insertions(+), 95 deletions(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index 0c934174..1bb270fe 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -62,7 +62,114 @@ function(absl_library) endif() endfunction() +# +# CMake function to imitate Bazel's cc_library rule. +# +# Parameters: +# NAME: name of target (see Note) +# HDRS: List of public header files for the library +# SRCS: List of source files for the library +# DEPS: List of other libraries to be linked in to the binary targets +# COPTS: List of private compile options +# DEFINES: List of public defines +# LINKOPTS: List of link options +# VISIBILITY_PUBLIC: Add this so that this library will be exported under absl:: (see Note). +# TESTONLY: When added, this target will only be built if user passes -DBUILD_TESTING=ON to CMake. +# +# Note: +# +# By default, absl_cc_library will always create a library named absl_${NAME}, +# which means other targets can only depend this library as absl_${NAME}, not ${NAME}. +# This is to reduce namespace pollution. +# +# absl_cc_library( +# NAME +# awesome_lib +# HDRS +# "a.h" +# SRCS +# "a.cc" +# ) +# absl_cc_library( +# NAME +# fantastic_lib +# SRCS +# "b.cc" +# DEPS +# absl_awesome_lib # not "awesome_lib"! +# ) +# +# If VISIBILITY_PUBLIC is set, absl_cc_library will also create an alias absl::${NAME} +# for public use. +# +# absl_cc_library( +# NAME +# main_lib +# ... +# VISIBILITY_PUBLIC +# ) +# +# User can then use the library as absl::main_lib (although absl_main_lib is defined too). +# +# TODO: Implement "ALWAYSLINK" +function(absl_cc_library) + cmake_parse_arguments(ABSL_CC_LIB + "DISABLE_INSTALL;VISIBILITY_PUBLIC;TESTONLY" + "NAME" + "HDRS;SRCS;COPTS;DEFINES;LINKOPTS;DEPS" + ${ARGN} + ) + + if (NOT ABSL_CC_LIB_TESTONLY OR BUILD_TESTING) + set(_NAME "absl_${ABSL_CC_LIB_NAME}") + string(TOUPPER ${_NAME} _UPPER_NAME) + + # Check if this is a header-only library + if (ABSL_CC_LIB_SRCS) + set(_SRCS ${ABSL_CC_LIB_SRCS}) + list(FILTER _SRCS INCLUDE REGEX "\.cc$") + list(LENGTH _SRCS ABSL_CC_LIB_SRCS_LEN) + else() + set(ABSL_CC_LIB_SRCS_LEN 0) + endif() + + if(ABSL_CC_LIB_SRCS_LEN) + add_library(${_NAME} STATIC ${ABSL_CC_LIB_SRCS} ${ABSL_CC_LIB_HDRS}) + else() + set(__dummy_header_only_lib_file "${CMAKE_CURRENT_BINARY_DIR}/${_NAME}_header_only_dummy.cc") + + if(NOT EXISTS ${__dummy_header_only_lib_file}) + file(WRITE ${__dummy_header_only_lib_file} + "/* generated file for header-only cmake target */ + + namespace absl { + // single meaningless symbol + void ${_NAME}__header_fakesym() {} + } // namespace absl") + endif() + + add_library(${_NAME} ${__dummy_header_only_lib_file} ${ABSL_CC_LIB_HDRS}) + endif() + + target_compile_options(${_NAME} PRIVATE ${ABSL_COMPILE_CXXFLAGS} ${ABSL_CC_LIB_COPTS}) + target_link_libraries(${_NAME} + PUBLIC ${ABSL_CC_LIB_DEPS} + PRIVATE ${ABSL_CC_LIB_LINKOPTS} + ) + target_compile_definitions(${_NAME} PUBLIC ${ABSL_CC_LIB_DEFINES}) + + target_include_directories(${_NAME} + PUBLIC ${ABSL_COMMON_INCLUDE_DIRS} + ) + # Add all Abseil targets to a a folder in the IDE for organization. + set_property(TARGET ${_NAME} PROPERTY FOLDER ${ABSL_IDE_FOLDER}) + + if(ABSL_CC_LIB_VISIBILITY_PUBLIC) + add_library(absl::${ABSL_CC_LIB_NAME} ALIAS ${_NAME}) + endif() + endif() +endfunction() # # header only virtual target creation diff --git a/absl/base/CMakeLists.txt b/absl/base/CMakeLists.txt index 04a6eb31..a73ea359 100644 --- a/absl/base/CMakeLists.txt +++ b/absl/base/CMakeLists.txt @@ -99,33 +99,26 @@ absl_library( throw_delegate ) -if(BUILD_TESTING) - # exception-safety testing library - set(EXCEPTION_SAFETY_TESTING_SRC + +# exception-safety testing library +absl_cc_library( + NAME + exception_safety_testing + HDRS "internal/exception_safety_testing.h" + SRCS "internal/exception_safety_testing.cc" - ) - set(EXCEPTION_SAFETY_TESTING_PUBLIC_LIBRARIES - ${ABSL_TEST_COMMON_LIBRARIES} + COPTS + ${ABSL_EXCEPTIONS_FLAG} + DEPS absl::base absl::memory absl::meta absl::strings absl::optional gtest - ) - -absl_library( - TARGET - absl_base_internal_exception_safety_testing - SOURCES - ${EXCEPTION_SAFETY_TESTING_SRC} - PUBLIC_LIBRARIES - ${EXCEPTION_SAFETY_TESTING_PUBLIC_LIBRARIES} - PRIVATE_COMPILE_FLAGS - ${ABSL_EXCEPTIONS_FLAG} + TESTONLY ) -endif() # dynamic_annotations library @@ -368,7 +361,7 @@ absl_test( set(EXCEPTION_SAFETY_TESTING_TEST_SRC "exception_safety_testing_test.cc") set(EXCEPTION_SAFETY_TESTING_TEST_PUBLIC_LIBRARIES absl::base - absl_base_internal_exception_safety_testing + absl_exception_safety_testing absl::memory absl::meta absl::strings diff --git a/absl/strings/CMakeLists.txt b/absl/strings/CMakeLists.txt index f3e41623..9fb96c7b 100644 --- a/absl/strings/CMakeLists.txt +++ b/absl/strings/CMakeLists.txt @@ -14,87 +14,71 @@ # limitations under the License. # - -list(APPEND STRINGS_PUBLIC_HEADERS - "ascii.h" - "charconv.h" - "escaping.h" - "match.h" - "numbers.h" - "str_cat.h" - "string_view.h" - "strip.h" - "str_join.h" - "str_replace.h" - "str_split.h" - "substitute.h" -) - - -list(APPEND STRINGS_INTERNAL_HEADERS - "internal/char_map.h" - "internal/charconv_bigint.h" - "internal/charconv_parse.h" - "internal/memutil.h" - "internal/ostringstream.h" - "internal/resize_uninitialized.h" - "internal/stl_type_traits.h" - "internal/str_join_internal.h" - "internal/str_split_internal.h" - "internal/utf8.h" -) - - - -# add string library -list(APPEND STRINGS_SRC - "ascii.cc" - "charconv.cc" - "escaping.cc" - "internal/charconv_bigint.cc" - "internal/charconv_parse.cc" - "internal/memutil.cc" - "internal/memutil.h" - "internal/utf8.cc" - "internal/ostringstream.cc" - "match.cc" - "numbers.cc" - "str_cat.cc" - "str_replace.cc" - "str_split.cc" - "string_view.cc" - "substitute.cc" - ${STRINGS_PUBLIC_HEADERS} - ${STRINGS_INTERNAL_HEADERS} -) -set(STRINGS_PUBLIC_LIBRARIES absl::base absl_throw_delegate) - -absl_library( - TARGET - absl_strings - SOURCES - ${STRINGS_SRC} - PUBLIC_LIBRARIES - ${STRINGS_PUBLIC_LIBRARIES} - EXPORT_NAME +absl_cc_library( + NAME strings + HDRS + "ascii.h" + "charconv.h" + "escaping.h" + "match.h" + "numbers.h" + "str_cat.h" + "string_view.h" + "strip.h" + "str_join.h" + "str_replace.h" + "str_split.h" + "substitute.h" + SRCS + "ascii.cc" + "charconv.cc" + "escaping.cc" + "internal/bits.h" + "internal/char_map.h" + "internal/charconv_bigint.cc" + "internal/charconv_bigint.h" + "internal/charconv_parse.cc" + "internal/charconv_parse.h" + "internal/memutil.cc" + "internal/memutil.h" + "internal/ostringstream.cc" + "internal/ostringstream.h" + "internal/resize_uninitialized.h" + "internal/stl_type_traits.h" + "internal/str_join_internal.h" + "internal/str_split_internal.h" + "internal/utf8.cc" + "internal/utf8.h" + "match.cc" + "numbers.cc" + "str_cat.cc" + "str_replace.cc" + "str_split.cc" + "string_view.cc" + "substitute.cc" + DEPS + absl::base + absl_throw_delegate + VISIBILITY_PUBLIC ) # add str_format library -absl_header_library( - TARGET - absl_str_format - PUBLIC_LIBRARIES - str_format_internal - EXPORT_NAME +absl_cc_library( + NAME str_format + HDRS + "str_format.h" + DEPS + absl_str_format_internal + VISIBILITY_PUBLIC ) # str_format_internal -absl_library( - TARGET +absl_cc_library( + NAME str_format_internal - SOURCES + SRCS "internal/str_format/arg.cc" "internal/str_format/bind.cc" "internal/str_format/extension.cc" @@ -108,7 +92,7 @@ absl_library( "internal/str_format/float_conversion.h" "internal/str_format/output.h" "internal/str_format/parser.h" - PUBLIC_LIBRARIES + DEPS str_format_extension_internal absl::strings absl::base @@ -415,7 +399,7 @@ absl_test( SOURCES "internal/str_format/bind_test.cc" PUBLIC_LIBRARIES - str_format_internal + absl_str_format_internal ) # test str_format_checker_test @@ -435,7 +419,7 @@ absl_test( SOURCES "internal/str_format/convert_test.cc" PUBLIC_LIBRARIES - str_format_internal + absl_str_format_internal absl::numeric ) @@ -456,7 +440,7 @@ absl_test( SOURCES "internal/str_format/parser_test.cc" PUBLIC_LIBRARIES - str_format_internal + absl_str_format_internal absl::base ) -- cgit v1.2.3 From fcc476cce5e88ae1f39ee7b1a46b46ca9c5de001 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Wed, 22 Aug 2018 17:00:51 +0800 Subject: Implement header-only target as INTERFACE lib --- CMake/AbseilHelpers.cmake | 44 ++++++++++++++++++-------------------------- 1 file changed, 18 insertions(+), 26 deletions(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index 1bb270fe..e9fc2a3a 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -136,35 +136,27 @@ function(absl_cc_library) if(ABSL_CC_LIB_SRCS_LEN) add_library(${_NAME} STATIC ${ABSL_CC_LIB_SRCS} ${ABSL_CC_LIB_HDRS}) + target_include_directories(${_NAME} + PUBLIC ${ABSL_COMMON_INCLUDE_DIRS}) + target_compile_options(${_NAME} + PRIVATE ${ABSL_COMPILE_CXXFLAGS} ${ABSL_CC_LIB_COPTS}) + target_link_libraries(${_NAME} + PUBLIC ${ABSL_CC_LIB_DEPS} + PRIVATE ${ABSL_CC_LIB_LINKOPTS} + ) + target_compile_definitions(${_NAME} PUBLIC ${ABSL_CC_LIB_DEFINES}) + + # Add all Abseil targets to a a folder in the IDE for organization. + set_property(TARGET ${_NAME} PROPERTY FOLDER ${ABSL_IDE_FOLDER}) else() - set(__dummy_header_only_lib_file "${CMAKE_CURRENT_BINARY_DIR}/${_NAME}_header_only_dummy.cc") - - if(NOT EXISTS ${__dummy_header_only_lib_file}) - file(WRITE ${__dummy_header_only_lib_file} - "/* generated file for header-only cmake target */ - - namespace absl { - // single meaningless symbol - void ${_NAME}__header_fakesym() {} - } // namespace absl") - endif() - - add_library(${_NAME} ${__dummy_header_only_lib_file} ${ABSL_CC_LIB_HDRS}) + add_library(${_NAME} INTERFACE) + target_include_directories(${_NAME} INTERFACE ${ABSL_COMMON_INCLUDE_DIRS}) + target_link_libraries(${_NAME} + INTERFACE ${ABSL_CC_LIB_DEPS} ${ABSL_CC_LIB_LINKOPTS} + ) + target_compile_definitions(${_NAME} INTERFACE ${ABSL_CC_LIB_DEFINES}) endif() - target_compile_options(${_NAME} PRIVATE ${ABSL_COMPILE_CXXFLAGS} ${ABSL_CC_LIB_COPTS}) - target_link_libraries(${_NAME} - PUBLIC ${ABSL_CC_LIB_DEPS} - PRIVATE ${ABSL_CC_LIB_LINKOPTS} - ) - target_compile_definitions(${_NAME} PUBLIC ${ABSL_CC_LIB_DEFINES}) - - target_include_directories(${_NAME} - PUBLIC ${ABSL_COMMON_INCLUDE_DIRS} - ) - # Add all Abseil targets to a a folder in the IDE for organization. - set_property(TARGET ${_NAME} PROPERTY FOLDER ${ABSL_IDE_FOLDER}) - if(ABSL_CC_LIB_VISIBILITY_PUBLIC) add_library(absl::${ABSL_CC_LIB_NAME} ALIAS ${_NAME}) endif() -- cgit v1.2.3 From 027ebfdb8fe9dc3fd85d34fbc5af0b2b7ac298f4 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Wed, 22 Aug 2018 20:47:11 +0800 Subject: Use ABSL_RUN_TESTS instead of BUILD_TESTING --- CMake/AbseilHelpers.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index e9fc2a3a..0b7b0b8d 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -121,7 +121,7 @@ function(absl_cc_library) ${ARGN} ) - if (NOT ABSL_CC_LIB_TESTONLY OR BUILD_TESTING) + if (NOT ABSL_CC_LIB_TESTONLY OR ABSL_RUN_TESTS) set(_NAME "absl_${ABSL_CC_LIB_NAME}") string(TOUPPER ${_NAME} _UPPER_NAME) -- cgit v1.2.3 From 73b908fbcf9821fb2b1d4975d5cd03002f2fa7f7 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Wed, 22 Aug 2018 21:13:18 +0800 Subject: Migrate some internal base targets --- absl/base/CMakeLists.txt | 61 +++++++++++++++++++++--------------------------- 1 file changed, 27 insertions(+), 34 deletions(-) diff --git a/absl/base/CMakeLists.txt b/absl/base/CMakeLists.txt index a73ea359..eb29cd28 100644 --- a/absl/base/CMakeLists.txt +++ b/absl/base/CMakeLists.txt @@ -83,20 +83,17 @@ absl_library( base ) -# throw delegate library -set(THROW_DELEGATE_SRC "internal/throw_delegate.cc") - -absl_library( - TARGET - absl_throw_delegate - SOURCES - ${THROW_DELEGATE_SRC} - PUBLIC_LIBRARIES - ${THROW_DELEGATE_PUBLIC_LIBRARIES} - PRIVATE_COMPILE_FLAGS - ${ABSL_EXCEPTIONS_FLAG} - EXPORT_NAME +absl_cc_library( + NAME throw_delegate + SRCS + "internal/throw_delegate.cc" + HDRS + "internal/throw_delegate.h" + COPTS + ${ABSL_EXCEPTIONS_FLAG} + DEPS + absl::base ) @@ -131,29 +128,25 @@ absl_library( ${DYNAMIC_ANNOTATIONS_SRC} ) - -# spinlock_wait library -set(SPINLOCK_WAIT_SRC "internal/spinlock_wait.cc") - -absl_library( - TARGET - absl_spinlock_wait - SOURCES - ${SPINLOCK_WAIT_SRC} -) - - -# malloc_internal library -list(APPEND MALLOC_INTERNAL_SRC - "internal/low_level_alloc.cc" +absl_cc_library( + NAME + spinlock_wait + SRCS + "internal/spinlock_wait.cc" + HDRS + "internal/scheduling_mode.h" + "internal/spinlock_wait.h" ) -absl_library( - TARGET - absl_malloc_internal - SOURCES - ${MALLOC_INTERNAL_SRC} - PUBLIC_LIBRARIES +absl_cc_library( + NAME + malloc_internal + SRCS + "internal/low_level_alloc.cc" + HDRS + "internal/direct_mmap.h" + "internal/low_level_alloc.h" + DEPS absl_dynamic_annotations ) -- cgit v1.2.3 From f1c17a303a07eeddf83bb68accaf342939b1431a Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Wed, 22 Aug 2018 21:14:38 +0800 Subject: Revert migration for //absl/strings/... --- absl/strings/CMakeLists.txt | 137 +++++++++++++++++++++++++------------------- 1 file changed, 77 insertions(+), 60 deletions(-) diff --git a/absl/strings/CMakeLists.txt b/absl/strings/CMakeLists.txt index 9fb96c7b..cd122134 100644 --- a/absl/strings/CMakeLists.txt +++ b/absl/strings/CMakeLists.txt @@ -14,71 +14,88 @@ # limitations under the License. # -absl_cc_library( - NAME + +list(APPEND STRINGS_PUBLIC_HEADERS + "ascii.h" + "charconv.h" + "escaping.h" + "match.h" + "numbers.h" + "str_cat.h" + "string_view.h" + "strip.h" + "str_join.h" + "str_replace.h" + "str_split.h" + "substitute.h" +) + + +list(APPEND STRINGS_INTERNAL_HEADERS + "internal/bits.h" + "internal/char_map.h" + "internal/charconv_bigint.h" + "internal/charconv_parse.h" + "internal/memutil.h" + "internal/ostringstream.h" + "internal/resize_uninitialized.h" + "internal/stl_type_traits.h" + "internal/str_join_internal.h" + "internal/str_split_internal.h" + "internal/utf8.h" +) + + + +# add string library +list(APPEND STRINGS_SRC + "ascii.cc" + "charconv.cc" + "escaping.cc" + "internal/charconv_bigint.cc" + "internal/charconv_parse.cc" + "internal/memutil.cc" + "internal/memutil.h" + "internal/utf8.cc" + "internal/ostringstream.cc" + "match.cc" + "numbers.cc" + "str_cat.cc" + "str_replace.cc" + "str_split.cc" + "string_view.cc" + "substitute.cc" + ${STRINGS_PUBLIC_HEADERS} + ${STRINGS_INTERNAL_HEADERS} +) +set(STRINGS_PUBLIC_LIBRARIES absl::base absl_throw_delegate) + +absl_library( + TARGET + absl_strings + SOURCES + ${STRINGS_SRC} + PUBLIC_LIBRARIES + ${STRINGS_PUBLIC_LIBRARIES} + EXPORT_NAME strings - HDRS - "ascii.h" - "charconv.h" - "escaping.h" - "match.h" - "numbers.h" - "str_cat.h" - "string_view.h" - "strip.h" - "str_join.h" - "str_replace.h" - "str_split.h" - "substitute.h" - SRCS - "ascii.cc" - "charconv.cc" - "escaping.cc" - "internal/bits.h" - "internal/char_map.h" - "internal/charconv_bigint.cc" - "internal/charconv_bigint.h" - "internal/charconv_parse.cc" - "internal/charconv_parse.h" - "internal/memutil.cc" - "internal/memutil.h" - "internal/ostringstream.cc" - "internal/ostringstream.h" - "internal/resize_uninitialized.h" - "internal/stl_type_traits.h" - "internal/str_join_internal.h" - "internal/str_split_internal.h" - "internal/utf8.cc" - "internal/utf8.h" - "match.cc" - "numbers.cc" - "str_cat.cc" - "str_replace.cc" - "str_split.cc" - "string_view.cc" - "substitute.cc" - DEPS - absl::base - absl_throw_delegate - VISIBILITY_PUBLIC ) # add str_format library -absl_cc_library( - NAME +absl_header_library( + TARGET + absl_str_format + PUBLIC_LIBRARIES + str_format_internal + EXPORT_NAME str_format - HDRS - "str_format.h" - DEPS - absl_str_format_internal - VISIBILITY_PUBLIC ) # str_format_internal -absl_cc_library( - NAME +absl_library( + TARGET str_format_internal - SRCS + SOURCES "internal/str_format/arg.cc" "internal/str_format/bind.cc" "internal/str_format/extension.cc" @@ -92,7 +109,7 @@ absl_cc_library( "internal/str_format/float_conversion.h" "internal/str_format/output.h" "internal/str_format/parser.h" - DEPS + PUBLIC_LIBRARIES str_format_extension_internal absl::strings absl::base @@ -399,7 +416,7 @@ absl_test( SOURCES "internal/str_format/bind_test.cc" PUBLIC_LIBRARIES - absl_str_format_internal + str_format_internal ) # test str_format_checker_test @@ -419,7 +436,7 @@ absl_test( SOURCES "internal/str_format/convert_test.cc" PUBLIC_LIBRARIES - absl_str_format_internal + str_format_internal absl::numeric ) @@ -440,7 +457,7 @@ absl_test( SOURCES "internal/str_format/parser_test.cc" PUBLIC_LIBRARIES - absl_str_format_internal + str_format_internal absl::base ) -- cgit v1.2.3 From 1ecb60be3901a3e582ed202dd04f083de9f6f20c Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Fri, 24 Aug 2018 10:11:09 +0800 Subject: Set default prefix to absl_internal_ --- CMake/AbseilHelpers.cmake | 10 +++++----- absl/base/CMakeLists.txt | 6 +++--- absl/container/CMakeLists.txt | 8 ++++---- absl/debugging/CMakeLists.txt | 2 +- absl/memory/CMakeLists.txt | 2 +- absl/strings/CMakeLists.txt | 8 ++++---- absl/types/CMakeLists.txt | 10 +++++----- 7 files changed, 23 insertions(+), 23 deletions(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index 0b7b0b8d..d4f662b4 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -78,8 +78,8 @@ endfunction() # # Note: # -# By default, absl_cc_library will always create a library named absl_${NAME}, -# which means other targets can only depend this library as absl_${NAME}, not ${NAME}. +# By default, absl_cc_library will always create a library named absl_internal_${NAME}, +# which means other targets can only depend this library as absl_internal_${NAME}, not ${NAME}. # This is to reduce namespace pollution. # # absl_cc_library( @@ -96,11 +96,11 @@ endfunction() # SRCS # "b.cc" # DEPS -# absl_awesome_lib # not "awesome_lib"! +# absl_internal_awesome_lib # not "awesome_lib"! # ) # # If VISIBILITY_PUBLIC is set, absl_cc_library will also create an alias absl::${NAME} -# for public use. +# for public use in addition to absl_internal_${NAME}. # # absl_cc_library( # NAME @@ -122,7 +122,7 @@ function(absl_cc_library) ) if (NOT ABSL_CC_LIB_TESTONLY OR ABSL_RUN_TESTS) - set(_NAME "absl_${ABSL_CC_LIB_NAME}") + set(_NAME "absl_internal_${ABSL_CC_LIB_NAME}") string(TOUPPER ${_NAME} _UPPER_NAME) # Check if this is a header-only library diff --git a/absl/base/CMakeLists.txt b/absl/base/CMakeLists.txt index eb29cd28..202003e6 100644 --- a/absl/base/CMakeLists.txt +++ b/absl/base/CMakeLists.txt @@ -78,7 +78,7 @@ absl_library( ${BASE_SRC} PUBLIC_LIBRARIES absl_dynamic_annotations - absl_spinlock_wait + absl_internal_spinlock_wait EXPORT_NAME base ) @@ -197,7 +197,7 @@ absl_test( # test absl_throw_delegate_test set(THROW_DELEGATE_TEST_SRC "throw_delegate_test.cc") -set(THROW_DELEGATE_TEST_PUBLIC_LIBRARIES absl::base absl_throw_delegate) +set(THROW_DELEGATE_TEST_PUBLIC_LIBRARIES absl::base absl_internal_throw_delegate) absl_test( TARGET @@ -354,7 +354,7 @@ absl_test( set(EXCEPTION_SAFETY_TESTING_TEST_SRC "exception_safety_testing_test.cc") set(EXCEPTION_SAFETY_TESTING_TEST_PUBLIC_LIBRARIES absl::base - absl_exception_safety_testing + absl_internal_exception_safety_testing absl::memory absl::meta absl::strings diff --git a/absl/container/CMakeLists.txt b/absl/container/CMakeLists.txt index 710bace7..087eddfd 100644 --- a/absl/container/CMakeLists.txt +++ b/absl/container/CMakeLists.txt @@ -80,7 +80,7 @@ absl_library( # test fixed_array_test set(FIXED_ARRAY_TEST_SRC "fixed_array_test.cc") -set(FIXED_ARRAY_TEST_PUBLIC_LIBRARIES absl::base absl_throw_delegate test_instance_tracker_lib) +set(FIXED_ARRAY_TEST_PUBLIC_LIBRARIES absl::base absl_internal_throw_delegate test_instance_tracker_lib) absl_test( TARGET @@ -109,7 +109,7 @@ absl_test( set(FIXED_ARRAY_EXCEPTION_SAFETY_TEST_SRC "fixed_array_exception_safety_test.cc") set(FIXED_ARRAY_EXCEPTION_SAFETY_TEST_PUBLIC_LIBRARIES absl::container - absl_base_internal_exception_safety_testing + absl_internal_exception_safety_testing ) absl_test( @@ -126,7 +126,7 @@ absl_test( # test inlined_vector_test set(INLINED_VECTOR_TEST_SRC "inlined_vector_test.cc") -set(INLINED_VECTOR_TEST_PUBLIC_LIBRARIES absl::base absl_throw_delegate test_instance_tracker_lib) +set(INLINED_VECTOR_TEST_PUBLIC_LIBRARIES absl::base absl_internal_throw_delegate test_instance_tracker_lib) absl_test( TARGET @@ -151,7 +151,7 @@ absl_test( # test test_instance_tracker_test set(TEST_INSTANCE_TRACKER_TEST_SRC "internal/test_instance_tracker_test.cc") -set(TEST_INSTANCE_TRACKER_TEST_PUBLIC_LIBRARIES absl::base absl_throw_delegate test_instance_tracker_lib) +set(TEST_INSTANCE_TRACKER_TEST_PUBLIC_LIBRARIES absl::base absl_internal_throw_delegate test_instance_tracker_lib) absl_test( diff --git a/absl/debugging/CMakeLists.txt b/absl/debugging/CMakeLists.txt index 4af2ec8a..266c2ca0 100644 --- a/absl/debugging/CMakeLists.txt +++ b/absl/debugging/CMakeLists.txt @@ -85,7 +85,7 @@ absl_library( ${SYMBOLIZE_SRC} PUBLIC_LIBRARIES absl::base - absl_malloc_internal + absl_internal_malloc_internal EXPORT_NAME symbolize ) diff --git a/absl/memory/CMakeLists.txt b/absl/memory/CMakeLists.txt index 5958f5c5..7d731e8a 100644 --- a/absl/memory/CMakeLists.txt +++ b/absl/memory/CMakeLists.txt @@ -53,7 +53,7 @@ absl_test( set(MEMORY_EXCEPTION_SAFETY_TEST_SRC "memory_exception_safety_test.cc") set(MEMORY_EXCEPTION_SAFETY_TEST_PUBLIC_LIBRARIES absl::memory - absl_base_internal_exception_safety_testing + absl_internal_exception_safety_testing ) absl_test( diff --git a/absl/strings/CMakeLists.txt b/absl/strings/CMakeLists.txt index cd122134..9ee3fc2a 100644 --- a/absl/strings/CMakeLists.txt +++ b/absl/strings/CMakeLists.txt @@ -68,7 +68,7 @@ list(APPEND STRINGS_SRC ${STRINGS_PUBLIC_HEADERS} ${STRINGS_INTERNAL_HEADERS} ) -set(STRINGS_PUBLIC_LIBRARIES absl::base absl_throw_delegate) +set(STRINGS_PUBLIC_LIBRARIES absl::base absl_internal_throw_delegate) absl_library( TARGET @@ -208,7 +208,7 @@ absl_test( # test string_view_test set(STRING_VIEW_TEST_SRC "string_view_test.cc") -set(STRING_VIEW_TEST_PUBLIC_LIBRARIES absl::strings absl_throw_delegate absl::base) +set(STRING_VIEW_TEST_PUBLIC_LIBRARIES absl::strings absl_internal_throw_delegate absl::base) absl_test( TARGET @@ -236,7 +236,7 @@ absl_test( # test str_replace_test set(STR_REPLACE_TEST_SRC "str_replace_test.cc") -set(STR_REPLACE_TEST_PUBLIC_LIBRARIES absl::strings absl::base absl_throw_delegate) +set(STR_REPLACE_TEST_PUBLIC_LIBRARIES absl::strings absl::base absl_internal_throw_delegate) absl_test( TARGET @@ -250,7 +250,7 @@ absl_test( # test str_split_test set(STR_SPLIT_TEST_SRC "str_split_test.cc") -set(STR_SPLIT_TEST_PUBLIC_LIBRARIES absl::strings absl::base absl_throw_delegate) +set(STR_SPLIT_TEST_PUBLIC_LIBRARIES absl::strings absl::base absl_internal_throw_delegate) absl_test( TARGET diff --git a/absl/types/CMakeLists.txt b/absl/types/CMakeLists.txt index 2f2e3a77..bc6c39e9 100644 --- a/absl/types/CMakeLists.txt +++ b/absl/types/CMakeLists.txt @@ -123,7 +123,7 @@ absl_library( # test any_test set(ANY_TEST_SRC "any_test.cc") -set(ANY_TEST_PUBLIC_LIBRARIES absl::base absl::throw_delegate absl::any absl::bad_any_cast test_instance_tracker_lib) +set(ANY_TEST_PUBLIC_LIBRARIES absl::base absl_internal_throw_delegate absl::any absl::bad_any_cast test_instance_tracker_lib) absl_test( TARGET @@ -152,7 +152,7 @@ set(ANY_EXCEPTION_SAFETY_TEST_SRC "any_exception_safety_test.cc") set(ANY_EXCEPTION_SAFETY_TEST_PUBLIC_LIBRARIES absl::any absl::base - absl_base_internal_exception_safety_testing + absl_internal_exception_safety_testing ) absl_test( @@ -169,7 +169,7 @@ absl_test( # test span_test set(SPAN_TEST_SRC "span_test.cc") -set(SPAN_TEST_PUBLIC_LIBRARIES absl::base absl::strings absl::throw_delegate absl::span test_instance_tracker_lib) +set(SPAN_TEST_PUBLIC_LIBRARIES absl::base absl::strings absl_internal_throw_delegate absl::span test_instance_tracker_lib) absl_test( TARGET @@ -197,7 +197,7 @@ absl_test( # test optional_test set(OPTIONAL_TEST_SRC "optional_test.cc") -set(OPTIONAL_TEST_PUBLIC_LIBRARIES absl::base absl::throw_delegate absl::optional absl_bad_optional_access) +set(OPTIONAL_TEST_PUBLIC_LIBRARIES absl::base absl_internal_throw_delegate absl::optional absl_bad_optional_access) absl_test( TARGET @@ -213,7 +213,7 @@ absl_test( set(OPTIONAL_EXCEPTION_SAFETY_TEST_SRC "optional_exception_safety_test.cc") set(OPTIONAL_EXCEPTION_SAFETY_TEST_PUBLIC_LIBRARIES absl::optional - absl_base_internal_exception_safety_testing + absl_internal_exception_safety_testing ) absl_test( -- cgit v1.2.3 From 67058cbbe6df1d8105d311609fc8f06cdbabdd19 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Fri, 24 Aug 2018 10:13:30 +0800 Subject: Fix one comment --- CMake/AbseilHelpers.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index d4f662b4..f64831e3 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -109,7 +109,7 @@ endfunction() # VISIBILITY_PUBLIC # ) # -# User can then use the library as absl::main_lib (although absl_main_lib is defined too). +# User can then use the library as absl::main_lib (although absl_internal_main_lib is defined too). # # TODO: Implement "ALWAYSLINK" -- cgit v1.2.3 From 6b16ba047a6a7ee44380fc39b50ab135fecf09c7 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Sat, 25 Aug 2018 11:31:14 +0800 Subject: Convert VISIBILITY_PUBLIC to PUBLIC --- CMake/AbseilHelpers.cmake | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index f64831e3..e73a2ab3 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -73,7 +73,7 @@ endfunction() # COPTS: List of private compile options # DEFINES: List of public defines # LINKOPTS: List of link options -# VISIBILITY_PUBLIC: Add this so that this library will be exported under absl:: (see Note). +# PUBLIC: Add this so that this library will be exported under absl:: (see Note). # TESTONLY: When added, this target will only be built if user passes -DBUILD_TESTING=ON to CMake. # # Note: @@ -99,14 +99,14 @@ endfunction() # absl_internal_awesome_lib # not "awesome_lib"! # ) # -# If VISIBILITY_PUBLIC is set, absl_cc_library will also create an alias absl::${NAME} +# If PUBLIC is set, absl_cc_library will also create an alias absl::${NAME} # for public use in addition to absl_internal_${NAME}. # # absl_cc_library( # NAME # main_lib # ... -# VISIBILITY_PUBLIC +# PUBLIC # ) # # User can then use the library as absl::main_lib (although absl_internal_main_lib is defined too). @@ -115,7 +115,7 @@ endfunction() function(absl_cc_library) cmake_parse_arguments(ABSL_CC_LIB - "DISABLE_INSTALL;VISIBILITY_PUBLIC;TESTONLY" + "DISABLE_INSTALL;PUBLIC;TESTONLY" "NAME" "HDRS;SRCS;COPTS;DEFINES;LINKOPTS;DEPS" ${ARGN} @@ -123,7 +123,6 @@ function(absl_cc_library) if (NOT ABSL_CC_LIB_TESTONLY OR ABSL_RUN_TESTS) set(_NAME "absl_internal_${ABSL_CC_LIB_NAME}") - string(TOUPPER ${_NAME} _UPPER_NAME) # Check if this is a header-only library if (ABSL_CC_LIB_SRCS) @@ -157,7 +156,7 @@ function(absl_cc_library) target_compile_definitions(${_NAME} INTERFACE ${ABSL_CC_LIB_DEFINES}) endif() - if(ABSL_CC_LIB_VISIBILITY_PUBLIC) + if(ABSL_CC_LIB_PUBLIC) add_library(absl::${ABSL_CC_LIB_NAME} ALIAS ${_NAME}) endif() endif() -- cgit v1.2.3 From a76ceed6f68efc9efa64b7a849e9ec7e670030b2 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Tue, 9 Oct 2018 23:36:24 +0800 Subject: Add comment and todo --- CMake/AbseilHelpers.cmake | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index e73a2ab3..41d66d7e 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -137,6 +137,7 @@ function(absl_cc_library) add_library(${_NAME} STATIC ${ABSL_CC_LIB_SRCS} ${ABSL_CC_LIB_HDRS}) target_include_directories(${_NAME} PUBLIC ${ABSL_COMMON_INCLUDE_DIRS}) + # TODO(rongjiecomputer): Revisit ABSL_COMPILE_CXXFLAGS when fixing GH#123 target_compile_options(${_NAME} PRIVATE ${ABSL_COMPILE_CXXFLAGS} ${ABSL_CC_LIB_COPTS}) target_link_libraries(${_NAME} @@ -148,6 +149,7 @@ function(absl_cc_library) # Add all Abseil targets to a a folder in the IDE for organization. set_property(TARGET ${_NAME} PROPERTY FOLDER ${ABSL_IDE_FOLDER}) else() + # Generating header-only library add_library(${_NAME} INTERFACE) target_include_directories(${_NAME} INTERFACE ${ABSL_COMMON_INCLUDE_DIRS}) target_link_libraries(${_NAME} -- cgit v1.2.3 From fc2185a7f42aa244d716fff7563e241d797d0fed Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Wed, 10 Oct 2018 23:15:55 +0800 Subject: Use absl_ prefix for public target --- CMake/AbseilHelpers.cmake | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index 41d66d7e..1f33fd76 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -122,7 +122,11 @@ function(absl_cc_library) ) if (NOT ABSL_CC_LIB_TESTONLY OR ABSL_RUN_TESTS) - set(_NAME "absl_internal_${ABSL_CC_LIB_NAME}") + if (ABSL_CC_LIB_PUBLIC) + set(_NAME "absl_${ABSL_CC_LIB_NAME}") + else() + set(_NAME "absl_internal_${ABSL_CC_LIB_NAME}") + endif() # Check if this is a header-only library if (ABSL_CC_LIB_SRCS) -- cgit v1.2.3 From f59e0f1d089d647bdc441a20a2bea10963c0e5a7 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Wed, 10 Oct 2018 23:20:24 +0800 Subject: Update comments too --- CMake/AbseilHelpers.cmake | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index 1f33fd76..a376721e 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -99,8 +99,8 @@ endfunction() # absl_internal_awesome_lib # not "awesome_lib"! # ) # -# If PUBLIC is set, absl_cc_library will also create an alias absl::${NAME} -# for public use in addition to absl_internal_${NAME}. +# If PUBLIC is set, absl_cc_library will instead create a target named +# absl_${NAME} and an alias absl::${NAME}. # # absl_cc_library( # NAME @@ -109,7 +109,7 @@ endfunction() # PUBLIC # ) # -# User can then use the library as absl::main_lib (although absl_internal_main_lib is defined too). +# User can then use the library as absl::main_lib (although absl_main_lib is defined too). # # TODO: Implement "ALWAYSLINK" -- cgit v1.2.3 From dadcd56b4bdab6a9cefc7528f10b20d03fa61f88 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Thu, 11 Oct 2018 17:20:05 +0800 Subject: Use target_sources and remove one non-existent file --- CMake/AbseilHelpers.cmake | 13 ++++++------- absl/strings/CMakeLists.txt | 1 - 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index a376721e..3ed58a05 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -129,16 +129,15 @@ function(absl_cc_library) endif() # Check if this is a header-only library - if (ABSL_CC_LIB_SRCS) - set(_SRCS ${ABSL_CC_LIB_SRCS}) - list(FILTER _SRCS INCLUDE REGEX "\.cc$") - list(LENGTH _SRCS ABSL_CC_LIB_SRCS_LEN) + if ("${ABSL_CC_LIB_SRCS}" STREQUAL "") + set(ABSL_CC_LIB_IS_INTERFACE 1) else() - set(ABSL_CC_LIB_SRCS_LEN 0) + set(ABSL_CC_LIB_IS_INTERFACE 0) endif() - if(ABSL_CC_LIB_SRCS_LEN) - add_library(${_NAME} STATIC ${ABSL_CC_LIB_SRCS} ${ABSL_CC_LIB_HDRS}) + if(NOT ABSL_CC_LIB_IS_INTERFACE) + add_library(${_NAME} STATIC "") + target_sources(${_NAME} PRIVATE ${ABSL_CC_LIB_SRCS} ${ABSL_CC_LIB_HDRS}) target_include_directories(${_NAME} PUBLIC ${ABSL_COMMON_INCLUDE_DIRS}) # TODO(rongjiecomputer): Revisit ABSL_COMPILE_CXXFLAGS when fixing GH#123 diff --git a/absl/strings/CMakeLists.txt b/absl/strings/CMakeLists.txt index 9ee3fc2a..4df3bac3 100644 --- a/absl/strings/CMakeLists.txt +++ b/absl/strings/CMakeLists.txt @@ -32,7 +32,6 @@ list(APPEND STRINGS_PUBLIC_HEADERS list(APPEND STRINGS_INTERNAL_HEADERS - "internal/bits.h" "internal/char_map.h" "internal/charconv_bigint.h" "internal/charconv_parse.h" -- cgit v1.2.3 From bd2d9a420747665ff7a85257b2d72df4c97e4cd6 Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Sat, 13 Oct 2018 07:42:05 +0800 Subject: Update TESONLY comment --- CMake/AbseilHelpers.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index 3ed58a05..96813b08 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -74,7 +74,7 @@ endfunction() # DEFINES: List of public defines # LINKOPTS: List of link options # PUBLIC: Add this so that this library will be exported under absl:: (see Note). -# TESTONLY: When added, this target will only be built if user passes -DBUILD_TESTING=ON to CMake. +# TESTONLY: When added, this target will only be built if user passes -DABSL_RUN_TESTS=ON to CMake. # # Note: # -- cgit v1.2.3