From 07026622ab10078b84a1d51d17c9b9d7518c45a4 Mon Sep 17 00:00:00 2001 From: "H. Vetinari" Date: Sun, 7 May 2023 18:24:46 +1100 Subject: [PATCH 1/3] add some necessary source files to ABSL_INTERNAL_TEST_DLL_FILES --- CMake/AbseilDll.cmake | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/CMake/AbseilDll.cmake b/CMake/AbseilDll.cmake index 32b51411abc..aa73ae5135c 100644 --- a/CMake/AbseilDll.cmake +++ b/CMake/AbseilDll.cmake @@ -589,6 +589,10 @@ set(ABSL_INTERNAL_TEST_DLL_FILES "hash/hash_testing.h" "log/scoped_mock_log.cc" "log/scoped_mock_log.h" + "random/internal/chi_square.cc" + "random/internal/chi_square.h" + "random/internal/distribution_test_util.cc" + "random/internal/distribution_test_util.h" "random/internal/mock_helpers.h" "random/internal/mock_overload_set.h" "random/mocking_bit_gen.h" From 23bbcc4306f58cf3cfffbcb7fad8c185d18cb4cd Mon Sep 17 00:00:00 2001 From: "H. Vetinari" Date: Sun, 7 May 2023 20:26:19 +1100 Subject: [PATCH 2/3] update ABSL_CC_TEST_LINKOPTS when using shared build --- CMake/AbseilHelpers.cmake | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/CMake/AbseilHelpers.cmake b/CMake/AbseilHelpers.cmake index f1b3158ca58..de63531b7f7 100644 --- a/CMake/AbseilHelpers.cmake +++ b/CMake/AbseilHelpers.cmake @@ -413,6 +413,10 @@ function(absl_cc_test) DEPS ${ABSL_CC_TEST_DEPS} OUTPUT ABSL_CC_TEST_DEPS ) + absl_internal_dll_targets( + DEPS ${ABSL_CC_TEST_LINKOPTS} + OUTPUT ABSL_CC_TEST_LINKOPTS + ) else() target_compile_definitions(${_NAME} PUBLIC From 9e87faade4cbcc63d94e7fb61bc9fef4d7b4229c Mon Sep 17 00:00:00 2001 From: "H. Vetinari" Date: Mon, 8 May 2023 11:15:46 +1100 Subject: [PATCH 3/3] make CordzHandle and relevant internal state use ABSL_DLL --- absl/strings/internal/cord_internal.cc | 2 +- absl/strings/internal/cord_internal.h | 2 +- absl/strings/internal/cordz_handle.h | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/absl/strings/internal/cord_internal.cc b/absl/strings/internal/cord_internal.cc index b6b06cfa2a3..f28425113af 100644 --- a/absl/strings/internal/cord_internal.cc +++ b/absl/strings/internal/cord_internal.cc @@ -33,7 +33,7 @@ ABSL_CONST_INIT std::atomic cord_ring_buffer_enabled( kCordEnableRingBufferDefault); ABSL_CONST_INIT std::atomic shallow_subcords_enabled( kCordShallowSubcordsDefault); -ABSL_CONST_INIT std::atomic cord_btree_exhaustive_validation(false); +ABSL_CONST_INIT ABSL_DLL std::atomic cord_btree_exhaustive_validation(false); void LogFatalNodeType(CordRep* rep) { ABSL_INTERNAL_LOG(FATAL, absl::StrCat("Unexpected node type: ", diff --git a/absl/strings/internal/cord_internal.h b/absl/strings/internal/cord_internal.h index e6f0d544b6f..844e2f4a5ce 100644 --- a/absl/strings/internal/cord_internal.h +++ b/absl/strings/internal/cord_internal.h @@ -73,7 +73,7 @@ extern std::atomic shallow_subcords_enabled; // in debug assertions, and code that calls `IsValid()` explicitly. By default, // assertions should be relatively cheap and AssertValid() can easily lead to // O(n^2) complexity as recursive / full tree validation is O(n). -extern std::atomic cord_btree_exhaustive_validation; +ABSL_DLL extern std::atomic cord_btree_exhaustive_validation; inline void enable_cord_ring_buffer(bool enable) { cord_ring_buffer_enabled.store(enable, std::memory_order_relaxed); diff --git a/absl/strings/internal/cordz_handle.h b/absl/strings/internal/cordz_handle.h index 3c800b433fb..c4ac7cb81fd 100644 --- a/absl/strings/internal/cordz_handle.h +++ b/absl/strings/internal/cordz_handle.h @@ -34,7 +34,7 @@ namespace cord_internal { // has gained visibility into a CordzInfo object, that CordzInfo object will not // be deleted prematurely. This allows the profiler to inspect all CordzInfo // objects that are alive without needing to hold a global lock. -class CordzHandle { +class ABSL_DLL CordzHandle { public: CordzHandle() : CordzHandle(false) {}