@nxtedition/rocksdb 15.2.2 → 15.2.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/settings.local.json +15 -1
- package/binding.cc +186 -128
- package/binding.gyp +32 -113
- package/build.sh +3 -0
- package/deps/rocksdb/rocksdb.gyp +3 -1
- package/index.js +3 -5
- package/package.json +1 -1
- package/prebuilds/darwin-arm64/@nxtedition+rocksdb.node +0 -0
- package/prebuilds/linux-x64/@nxtedition+rocksdb.node +0 -0
- package/util.h +62 -63
- package/deps/abseil-cpp/BUILD.bazel +0 -35
- package/deps/abseil-cpp/CMake/AbseilDll.cmake +0 -938
- package/deps/abseil-cpp/CMake/AbseilHelpers.cmake +0 -465
- package/deps/abseil-cpp/CMake/Googletest/CMakeLists.txt.in +0 -14
- package/deps/abseil-cpp/CMake/Googletest/DownloadGTest.cmake +0 -41
- package/deps/abseil-cpp/CMake/abslConfig.cmake.in +0 -8
- package/deps/abseil-cpp/CMake/install_test_project/CMakeLists.txt +0 -25
- package/deps/abseil-cpp/CMake/install_test_project/simple.cc +0 -32
- package/deps/abseil-cpp/CMake/install_test_project/test.sh +0 -113
- package/deps/abseil-cpp/CMakeLists.txt +0 -280
- package/deps/abseil-cpp/LICENSE +0 -203
- package/deps/abseil-cpp/MODULE.bazel +0 -43
- package/deps/abseil-cpp/PrivacyInfo.xcprivacy +0 -14
- package/deps/abseil-cpp/absl/BUILD.bazel +0 -62
- package/deps/abseil-cpp/absl/CMakeLists.txt +0 -45
- package/deps/abseil-cpp/absl/abseil.podspec.gen.py +0 -245
- package/deps/abseil-cpp/absl/algorithm/BUILD.bazel +0 -92
- package/deps/abseil-cpp/absl/algorithm/CMakeLists.txt +0 -72
- package/deps/abseil-cpp/absl/algorithm/algorithm.h +0 -64
- package/deps/abseil-cpp/absl/algorithm/algorithm_test.cc +0 -60
- package/deps/abseil-cpp/absl/algorithm/container.h +0 -1864
- package/deps/abseil-cpp/absl/algorithm/container_test.cc +0 -2232
- package/deps/abseil-cpp/absl/base/BUILD.bazel +0 -1036
- package/deps/abseil-cpp/absl/base/CMakeLists.txt +0 -881
- package/deps/abseil-cpp/absl/base/attributes.h +0 -1081
- package/deps/abseil-cpp/absl/base/attributes_test.cc +0 -43
- package/deps/abseil-cpp/absl/base/bit_cast_test.cc +0 -109
- package/deps/abseil-cpp/absl/base/c_header_test.c +0 -30
- package/deps/abseil-cpp/absl/base/call_once.h +0 -228
- package/deps/abseil-cpp/absl/base/call_once_test.cc +0 -107
- package/deps/abseil-cpp/absl/base/casts.cc +0 -61
- package/deps/abseil-cpp/absl/base/casts.h +0 -313
- package/deps/abseil-cpp/absl/base/casts_test.cc +0 -148
- package/deps/abseil-cpp/absl/base/config.h +0 -854
- package/deps/abseil-cpp/absl/base/config_test.cc +0 -60
- package/deps/abseil-cpp/absl/base/const_init.h +0 -76
- package/deps/abseil-cpp/absl/base/dynamic_annotations.h +0 -480
- package/deps/abseil-cpp/absl/base/exception_safety_testing_test.cc +0 -958
- package/deps/abseil-cpp/absl/base/fast_type_id.h +0 -73
- package/deps/abseil-cpp/absl/base/fast_type_id_test.cc +0 -130
- package/deps/abseil-cpp/absl/base/internal/atomic_hook.h +0 -200
- package/deps/abseil-cpp/absl/base/internal/atomic_hook_test.cc +0 -97
- package/deps/abseil-cpp/absl/base/internal/atomic_hook_test_helper.cc +0 -32
- package/deps/abseil-cpp/absl/base/internal/atomic_hook_test_helper.h +0 -34
- package/deps/abseil-cpp/absl/base/internal/cmake_thread_test.cc +0 -22
- package/deps/abseil-cpp/absl/base/internal/cycleclock.cc +0 -72
- package/deps/abseil-cpp/absl/base/internal/cycleclock.h +0 -144
- package/deps/abseil-cpp/absl/base/internal/cycleclock_config.h +0 -55
- package/deps/abseil-cpp/absl/base/internal/direct_mmap.h +0 -170
- package/deps/abseil-cpp/absl/base/internal/dynamic_annotations.h +0 -398
- package/deps/abseil-cpp/absl/base/internal/endian.h +0 -279
- package/deps/abseil-cpp/absl/base/internal/endian_test.cc +0 -263
- package/deps/abseil-cpp/absl/base/internal/errno_saver.h +0 -43
- package/deps/abseil-cpp/absl/base/internal/errno_saver_test.cc +0 -45
- package/deps/abseil-cpp/absl/base/internal/exception_safety_testing.cc +0 -79
- package/deps/abseil-cpp/absl/base/internal/exception_safety_testing.h +0 -1109
- package/deps/abseil-cpp/absl/base/internal/exception_testing.h +0 -42
- package/deps/abseil-cpp/absl/base/internal/hide_ptr.h +0 -51
- package/deps/abseil-cpp/absl/base/internal/iterator_traits.h +0 -75
- package/deps/abseil-cpp/absl/base/internal/iterator_traits_test.cc +0 -85
- package/deps/abseil-cpp/absl/base/internal/iterator_traits_test_helper.h +0 -97
- package/deps/abseil-cpp/absl/base/internal/low_level_alloc.cc +0 -661
- package/deps/abseil-cpp/absl/base/internal/low_level_alloc.h +0 -133
- package/deps/abseil-cpp/absl/base/internal/low_level_alloc_test.cc +0 -180
- package/deps/abseil-cpp/absl/base/internal/low_level_scheduling.h +0 -134
- package/deps/abseil-cpp/absl/base/internal/nullability_traits.h +0 -71
- package/deps/abseil-cpp/absl/base/internal/nullability_traits_test.cc +0 -98
- package/deps/abseil-cpp/absl/base/internal/per_thread_tls.h +0 -52
- package/deps/abseil-cpp/absl/base/internal/poison.cc +0 -85
- package/deps/abseil-cpp/absl/base/internal/poison.h +0 -59
- package/deps/abseil-cpp/absl/base/internal/poison_test.cc +0 -41
- package/deps/abseil-cpp/absl/base/internal/pretty_function.h +0 -33
- package/deps/abseil-cpp/absl/base/internal/raw_logging.cc +0 -279
- package/deps/abseil-cpp/absl/base/internal/raw_logging.h +0 -217
- package/deps/abseil-cpp/absl/base/internal/scheduling_mode.h +0 -58
- package/deps/abseil-cpp/absl/base/internal/scoped_set_env.cc +0 -81
- package/deps/abseil-cpp/absl/base/internal/scoped_set_env.h +0 -45
- package/deps/abseil-cpp/absl/base/internal/scoped_set_env_test.cc +0 -99
- package/deps/abseil-cpp/absl/base/internal/spinlock.cc +0 -225
- package/deps/abseil-cpp/absl/base/internal/spinlock.h +0 -310
- package/deps/abseil-cpp/absl/base/internal/spinlock_akaros.inc +0 -35
- package/deps/abseil-cpp/absl/base/internal/spinlock_benchmark.cc +0 -80
- package/deps/abseil-cpp/absl/base/internal/spinlock_linux.inc +0 -71
- package/deps/abseil-cpp/absl/base/internal/spinlock_posix.inc +0 -46
- package/deps/abseil-cpp/absl/base/internal/spinlock_wait.cc +0 -81
- package/deps/abseil-cpp/absl/base/internal/spinlock_wait.h +0 -95
- package/deps/abseil-cpp/absl/base/internal/spinlock_win32.inc +0 -40
- package/deps/abseil-cpp/absl/base/internal/strerror.cc +0 -88
- package/deps/abseil-cpp/absl/base/internal/strerror.h +0 -39
- package/deps/abseil-cpp/absl/base/internal/strerror_benchmark.cc +0 -29
- package/deps/abseil-cpp/absl/base/internal/strerror_test.cc +0 -89
- package/deps/abseil-cpp/absl/base/internal/sysinfo.cc +0 -494
- package/deps/abseil-cpp/absl/base/internal/sysinfo.h +0 -74
- package/deps/abseil-cpp/absl/base/internal/sysinfo_test.cc +0 -82
- package/deps/abseil-cpp/absl/base/internal/thread_identity.cc +0 -163
- package/deps/abseil-cpp/absl/base/internal/thread_identity.h +0 -273
- package/deps/abseil-cpp/absl/base/internal/thread_identity_benchmark.cc +0 -38
- package/deps/abseil-cpp/absl/base/internal/thread_identity_test.cc +0 -129
- package/deps/abseil-cpp/absl/base/internal/throw_delegate.cc +0 -203
- package/deps/abseil-cpp/absl/base/internal/throw_delegate.h +0 -75
- package/deps/abseil-cpp/absl/base/internal/tracing.cc +0 -39
- package/deps/abseil-cpp/absl/base/internal/tracing.h +0 -81
- package/deps/abseil-cpp/absl/base/internal/tracing_strong_test.cc +0 -117
- package/deps/abseil-cpp/absl/base/internal/tracing_weak_test.cc +0 -34
- package/deps/abseil-cpp/absl/base/internal/tsan_mutex_interface.h +0 -68
- package/deps/abseil-cpp/absl/base/internal/unaligned_access.h +0 -89
- package/deps/abseil-cpp/absl/base/internal/unique_small_name_test.cc +0 -77
- package/deps/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -134
- package/deps/abseil-cpp/absl/base/internal/unscaledcycleclock.h +0 -113
- package/deps/abseil-cpp/absl/base/internal/unscaledcycleclock_config.h +0 -62
- package/deps/abseil-cpp/absl/base/log_severity.cc +0 -56
- package/deps/abseil-cpp/absl/base/log_severity.h +0 -185
- package/deps/abseil-cpp/absl/base/log_severity_test.cc +0 -251
- package/deps/abseil-cpp/absl/base/macros.h +0 -243
- package/deps/abseil-cpp/absl/base/no_destructor.h +0 -191
- package/deps/abseil-cpp/absl/base/no_destructor_benchmark.cc +0 -165
- package/deps/abseil-cpp/absl/base/no_destructor_test.cc +0 -205
- package/deps/abseil-cpp/absl/base/nullability.h +0 -317
- package/deps/abseil-cpp/absl/base/nullability_default_nonnull_test.cc +0 -44
- package/deps/abseil-cpp/absl/base/nullability_test.cc +0 -90
- package/deps/abseil-cpp/absl/base/optimization.h +0 -310
- package/deps/abseil-cpp/absl/base/optimization_test.cc +0 -141
- package/deps/abseil-cpp/absl/base/options.h +0 -158
- package/deps/abseil-cpp/absl/base/policy_checks.h +0 -115
- package/deps/abseil-cpp/absl/base/port.h +0 -25
- package/deps/abseil-cpp/absl/base/prefetch.h +0 -209
- package/deps/abseil-cpp/absl/base/prefetch_test.cc +0 -64
- package/deps/abseil-cpp/absl/base/raw_logging_test.cc +0 -98
- package/deps/abseil-cpp/absl/base/spinlock_test_common.cc +0 -302
- package/deps/abseil-cpp/absl/base/thread_annotations.h +0 -333
- package/deps/abseil-cpp/absl/base/throw_delegate_test.cc +0 -175
- package/deps/abseil-cpp/absl/cleanup/BUILD.bazel +0 -74
- package/deps/abseil-cpp/absl/cleanup/CMakeLists.txt +0 -55
- package/deps/abseil-cpp/absl/cleanup/cleanup.h +0 -142
- package/deps/abseil-cpp/absl/cleanup/cleanup_test.cc +0 -309
- package/deps/abseil-cpp/absl/cleanup/internal/cleanup.h +0 -99
- package/deps/abseil-cpp/absl/container/BUILD.bazel +0 -1394
- package/deps/abseil-cpp/absl/container/CMakeLists.txt +0 -1239
- package/deps/abseil-cpp/absl/container/btree_benchmark.cc +0 -806
- package/deps/abseil-cpp/absl/container/btree_map.h +0 -941
- package/deps/abseil-cpp/absl/container/btree_set.h +0 -872
- package/deps/abseil-cpp/absl/container/btree_test.cc +0 -3653
- package/deps/abseil-cpp/absl/container/btree_test.h +0 -166
- package/deps/abseil-cpp/absl/container/chunked_queue.h +0 -755
- package/deps/abseil-cpp/absl/container/chunked_queue_benchmark.cc +0 -386
- package/deps/abseil-cpp/absl/container/chunked_queue_test.cc +0 -768
- package/deps/abseil-cpp/absl/container/fixed_array.h +0 -547
- package/deps/abseil-cpp/absl/container/fixed_array_benchmark.cc +0 -67
- package/deps/abseil-cpp/absl/container/fixed_array_exception_safety_test.cc +0 -201
- package/deps/abseil-cpp/absl/container/fixed_array_test.cc +0 -874
- package/deps/abseil-cpp/absl/container/flat_hash_map.h +0 -702
- package/deps/abseil-cpp/absl/container/flat_hash_map_test.cc +0 -451
- package/deps/abseil-cpp/absl/container/flat_hash_set.h +0 -590
- package/deps/abseil-cpp/absl/container/flat_hash_set_test.cc +0 -401
- package/deps/abseil-cpp/absl/container/hash_container_defaults.h +0 -45
- package/deps/abseil-cpp/absl/container/inlined_vector.h +0 -1025
- package/deps/abseil-cpp/absl/container/inlined_vector_benchmark.cc +0 -829
- package/deps/abseil-cpp/absl/container/inlined_vector_exception_safety_test.cc +0 -508
- package/deps/abseil-cpp/absl/container/inlined_vector_test.cc +0 -2278
- package/deps/abseil-cpp/absl/container/internal/btree.h +0 -3149
- package/deps/abseil-cpp/absl/container/internal/btree_container.h +0 -876
- package/deps/abseil-cpp/absl/container/internal/chunked_queue.h +0 -173
- package/deps/abseil-cpp/absl/container/internal/common.h +0 -301
- package/deps/abseil-cpp/absl/container/internal/common_policy_traits.h +0 -151
- package/deps/abseil-cpp/absl/container/internal/common_policy_traits_test.cc +0 -157
- package/deps/abseil-cpp/absl/container/internal/compressed_tuple.h +0 -275
- package/deps/abseil-cpp/absl/container/internal/compressed_tuple_test.cc +0 -469
- package/deps/abseil-cpp/absl/container/internal/container_memory.h +0 -561
- package/deps/abseil-cpp/absl/container/internal/container_memory_test.cc +0 -359
- package/deps/abseil-cpp/absl/container/internal/hash_function_defaults.h +0 -281
- package/deps/abseil-cpp/absl/container/internal/hash_function_defaults_test.cc +0 -633
- package/deps/abseil-cpp/absl/container/internal/hash_generator_testing.cc +0 -54
- package/deps/abseil-cpp/absl/container/internal/hash_generator_testing.h +0 -172
- package/deps/abseil-cpp/absl/container/internal/hash_policy_testing.h +0 -173
- package/deps/abseil-cpp/absl/container/internal/hash_policy_testing_test.cc +0 -45
- package/deps/abseil-cpp/absl/container/internal/hash_policy_traits.h +0 -195
- package/deps/abseil-cpp/absl/container/internal/hash_policy_traits_test.cc +0 -149
- package/deps/abseil-cpp/absl/container/internal/hashtable_control_bytes.h +0 -527
- package/deps/abseil-cpp/absl/container/internal/hashtable_control_bytes_test.cc +0 -259
- package/deps/abseil-cpp/absl/container/internal/hashtable_debug.h +0 -102
- package/deps/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +0 -85
- package/deps/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +0 -316
- package/deps/abseil-cpp/absl/container/internal/hashtablez_sampler.h +0 -311
- package/deps/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +0 -31
- package/deps/abseil-cpp/absl/container/internal/hashtablez_sampler_test.cc +0 -534
- package/deps/abseil-cpp/absl/container/internal/heterogeneous_lookup_testing.h +0 -80
- package/deps/abseil-cpp/absl/container/internal/inlined_vector.h +0 -1094
- package/deps/abseil-cpp/absl/container/internal/layout.h +0 -828
- package/deps/abseil-cpp/absl/container/internal/layout_benchmark.cc +0 -295
- package/deps/abseil-cpp/absl/container/internal/layout_test.cc +0 -2034
- package/deps/abseil-cpp/absl/container/internal/node_slot_policy.h +0 -95
- package/deps/abseil-cpp/absl/container/internal/node_slot_policy_test.cc +0 -71
- package/deps/abseil-cpp/absl/container/internal/raw_hash_map.h +0 -382
- package/deps/abseil-cpp/absl/container/internal/raw_hash_set.cc +0 -2090
- package/deps/abseil-cpp/absl/container/internal/raw_hash_set.h +0 -3763
- package/deps/abseil-cpp/absl/container/internal/raw_hash_set_allocator_test.cc +0 -525
- package/deps/abseil-cpp/absl/container/internal/raw_hash_set_benchmark.cc +0 -696
- package/deps/abseil-cpp/absl/container/internal/raw_hash_set_probe_benchmark.cc +0 -583
- package/deps/abseil-cpp/absl/container/internal/raw_hash_set_resize_impl.h +0 -79
- package/deps/abseil-cpp/absl/container/internal/raw_hash_set_resize_impl_test.cc +0 -66
- package/deps/abseil-cpp/absl/container/internal/raw_hash_set_test.cc +0 -4184
- package/deps/abseil-cpp/absl/container/internal/test_allocator.h +0 -387
- package/deps/abseil-cpp/absl/container/internal/test_instance_tracker.cc +0 -29
- package/deps/abseil-cpp/absl/container/internal/test_instance_tracker.h +0 -274
- package/deps/abseil-cpp/absl/container/internal/test_instance_tracker_test.cc +0 -184
- package/deps/abseil-cpp/absl/container/internal/tracked.h +0 -83
- package/deps/abseil-cpp/absl/container/internal/unordered_map_constructor_test.h +0 -435
- package/deps/abseil-cpp/absl/container/internal/unordered_map_lookup_test.h +0 -112
- package/deps/abseil-cpp/absl/container/internal/unordered_map_members_test.h +0 -87
- package/deps/abseil-cpp/absl/container/internal/unordered_map_modifiers_test.h +0 -336
- package/deps/abseil-cpp/absl/container/internal/unordered_map_test.cc +0 -50
- package/deps/abseil-cpp/absl/container/internal/unordered_set_constructor_test.h +0 -437
- package/deps/abseil-cpp/absl/container/internal/unordered_set_lookup_test.h +0 -88
- package/deps/abseil-cpp/absl/container/internal/unordered_set_members_test.h +0 -86
- package/deps/abseil-cpp/absl/container/internal/unordered_set_modifiers_test.h +0 -215
- package/deps/abseil-cpp/absl/container/internal/unordered_set_test.cc +0 -41
- package/deps/abseil-cpp/absl/container/linked_hash_map.h +0 -666
- package/deps/abseil-cpp/absl/container/linked_hash_map_benchmark.cc +0 -140
- package/deps/abseil-cpp/absl/container/linked_hash_map_test.cc +0 -987
- package/deps/abseil-cpp/absl/container/linked_hash_set.h +0 -527
- package/deps/abseil-cpp/absl/container/linked_hash_set_benchmark.cc +0 -84
- package/deps/abseil-cpp/absl/container/linked_hash_set_test.cc +0 -947
- package/deps/abseil-cpp/absl/container/node_hash_map.h +0 -698
- package/deps/abseil-cpp/absl/container/node_hash_map_test.cc +0 -348
- package/deps/abseil-cpp/absl/container/node_hash_set.h +0 -589
- package/deps/abseil-cpp/absl/container/node_hash_set_test.cc +0 -188
- package/deps/abseil-cpp/absl/container/sample_element_size_test.cc +0 -118
- package/deps/abseil-cpp/absl/copts/AbseilConfigureCopts.cmake +0 -106
- package/deps/abseil-cpp/absl/copts/GENERATED_AbseilCopts.cmake +0 -303
- package/deps/abseil-cpp/absl/copts/GENERATED_copts.bzl +0 -304
- package/deps/abseil-cpp/absl/copts/configure_copts.bzl +0 -39
- package/deps/abseil-cpp/absl/copts/copts.py +0 -205
- package/deps/abseil-cpp/absl/copts/generate_copts.py +0 -109
- package/deps/abseil-cpp/absl/crc/BUILD.bazel +0 -228
- package/deps/abseil-cpp/absl/crc/CMakeLists.txt +0 -177
- package/deps/abseil-cpp/absl/crc/crc32c.cc +0 -95
- package/deps/abseil-cpp/absl/crc/crc32c.h +0 -192
- package/deps/abseil-cpp/absl/crc/crc32c_benchmark.cc +0 -196
- package/deps/abseil-cpp/absl/crc/crc32c_test.cc +0 -257
- package/deps/abseil-cpp/absl/crc/internal/cpu_detect.cc +0 -359
- package/deps/abseil-cpp/absl/crc/internal/cpu_detect.h +0 -69
- package/deps/abseil-cpp/absl/crc/internal/crc.cc +0 -435
- package/deps/abseil-cpp/absl/crc/internal/crc.h +0 -83
- package/deps/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +0 -278
- package/deps/abseil-cpp/absl/crc/internal/crc32c.h +0 -39
- package/deps/abseil-cpp/absl/crc/internal/crc32c_inline.h +0 -72
- package/deps/abseil-cpp/absl/crc/internal/crc_cord_state.cc +0 -131
- package/deps/abseil-cpp/absl/crc/internal/crc_cord_state.h +0 -159
- package/deps/abseil-cpp/absl/crc/internal/crc_cord_state_test.cc +0 -124
- package/deps/abseil-cpp/absl/crc/internal/crc_internal.h +0 -161
- package/deps/abseil-cpp/absl/crc/internal/crc_memcpy.h +0 -122
- package/deps/abseil-cpp/absl/crc/internal/crc_memcpy_fallback.cc +0 -78
- package/deps/abseil-cpp/absl/crc/internal/crc_memcpy_test.cc +0 -177
- package/deps/abseil-cpp/absl/crc/internal/crc_memcpy_x86_arm_combined.cc +0 -459
- package/deps/abseil-cpp/absl/crc/internal/crc_non_temporal_memcpy.cc +0 -93
- package/deps/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +0 -762
- package/deps/abseil-cpp/absl/crc/internal/gen_crc32c_consts.py +0 -90
- package/deps/abseil-cpp/absl/crc/internal/non_temporal_arm_intrinsics.h +0 -81
- package/deps/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +0 -195
- package/deps/abseil-cpp/absl/crc/internal/non_temporal_memcpy_test.cc +0 -90
- package/deps/abseil-cpp/absl/debugging/BUILD.bazel +0 -483
- package/deps/abseil-cpp/absl/debugging/CMakeLists.txt +0 -448
- package/deps/abseil-cpp/absl/debugging/failure_signal_handler.cc +0 -434
- package/deps/abseil-cpp/absl/debugging/failure_signal_handler.h +0 -121
- package/deps/abseil-cpp/absl/debugging/failure_signal_handler_test.cc +0 -166
- package/deps/abseil-cpp/absl/debugging/internal/address_is_readable.cc +0 -98
- package/deps/abseil-cpp/absl/debugging/internal/address_is_readable.h +0 -32
- package/deps/abseil-cpp/absl/debugging/internal/addresses.h +0 -57
- package/deps/abseil-cpp/absl/debugging/internal/borrowed_fixup_buffer.cc +0 -118
- package/deps/abseil-cpp/absl/debugging/internal/borrowed_fixup_buffer.h +0 -71
- package/deps/abseil-cpp/absl/debugging/internal/borrowed_fixup_buffer_test.cc +0 -97
- package/deps/abseil-cpp/absl/debugging/internal/bounded_utf8_length_sequence.h +0 -126
- package/deps/abseil-cpp/absl/debugging/internal/bounded_utf8_length_sequence_test.cc +0 -126
- package/deps/abseil-cpp/absl/debugging/internal/decode_rust_punycode.cc +0 -258
- package/deps/abseil-cpp/absl/debugging/internal/decode_rust_punycode.h +0 -55
- package/deps/abseil-cpp/absl/debugging/internal/decode_rust_punycode_test.cc +0 -606
- package/deps/abseil-cpp/absl/debugging/internal/demangle.cc +0 -2958
- package/deps/abseil-cpp/absl/debugging/internal/demangle.h +0 -76
- package/deps/abseil-cpp/absl/debugging/internal/demangle_rust.cc +0 -925
- package/deps/abseil-cpp/absl/debugging/internal/demangle_rust.h +0 -42
- package/deps/abseil-cpp/absl/debugging/internal/demangle_rust_test.cc +0 -584
- package/deps/abseil-cpp/absl/debugging/internal/demangle_test.cc +0 -2050
- package/deps/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +0 -413
- package/deps/abseil-cpp/absl/debugging/internal/elf_mem_image.h +0 -141
- package/deps/abseil-cpp/absl/debugging/internal/examine_stack.cc +0 -334
- package/deps/abseil-cpp/absl/debugging/internal/examine_stack.h +0 -70
- package/deps/abseil-cpp/absl/debugging/internal/stack_consumption.cc +0 -206
- package/deps/abseil-cpp/absl/debugging/internal/stack_consumption.h +0 -50
- package/deps/abseil-cpp/absl/debugging/internal/stack_consumption_test.cc +0 -50
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +0 -288
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +0 -148
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_config.h +0 -96
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_emscripten-inl.inc +0 -112
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +0 -114
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +0 -270
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +0 -204
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +0 -25
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +0 -81
- package/deps/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +0 -410
- package/deps/abseil-cpp/absl/debugging/internal/symbolize.h +0 -153
- package/deps/abseil-cpp/absl/debugging/internal/utf8_for_code_point.cc +0 -70
- package/deps/abseil-cpp/absl/debugging/internal/utf8_for_code_point.h +0 -47
- package/deps/abseil-cpp/absl/debugging/internal/utf8_for_code_point_test.cc +0 -175
- package/deps/abseil-cpp/absl/debugging/internal/vdso_support.cc +0 -209
- package/deps/abseil-cpp/absl/debugging/internal/vdso_support.h +0 -158
- package/deps/abseil-cpp/absl/debugging/leak_check.cc +0 -73
- package/deps/abseil-cpp/absl/debugging/leak_check.h +0 -150
- package/deps/abseil-cpp/absl/debugging/leak_check_fail_test.cc +0 -41
- package/deps/abseil-cpp/absl/debugging/leak_check_test.cc +0 -41
- package/deps/abseil-cpp/absl/debugging/stacktrace.cc +0 -244
- package/deps/abseil-cpp/absl/debugging/stacktrace.h +0 -302
- package/deps/abseil-cpp/absl/debugging/stacktrace_benchmark.cc +0 -78
- package/deps/abseil-cpp/absl/debugging/stacktrace_test.cc +0 -505
- package/deps/abseil-cpp/absl/debugging/symbolize.cc +0 -44
- package/deps/abseil-cpp/absl/debugging/symbolize.h +0 -99
- package/deps/abseil-cpp/absl/debugging/symbolize_darwin.inc +0 -102
- package/deps/abseil-cpp/absl/debugging/symbolize_elf.inc +0 -1756
- package/deps/abseil-cpp/absl/debugging/symbolize_emscripten.inc +0 -63
- package/deps/abseil-cpp/absl/debugging/symbolize_test.cc +0 -619
- package/deps/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +0 -40
- package/deps/abseil-cpp/absl/debugging/symbolize_win32.inc +0 -99
- package/deps/abseil-cpp/absl/extend/CMakeLists.txt +0 -140
- package/deps/abseil-cpp/absl/extend/internal/BUILD.bazel +0 -127
- package/deps/abseil-cpp/absl/extend/internal/aggregate.h +0 -1687
- package/deps/abseil-cpp/absl/extend/internal/aggregate_test.cc +0 -867
- package/deps/abseil-cpp/absl/extend/internal/dependencies.h +0 -83
- package/deps/abseil-cpp/absl/extend/internal/dependencies_test.cc +0 -117
- package/deps/abseil-cpp/absl/extend/internal/is_tuple_hashable.h +0 -45
- package/deps/abseil-cpp/absl/extend/internal/num_bases.h +0 -87
- package/deps/abseil-cpp/absl/extend/internal/num_bases_test.cc +0 -91
- package/deps/abseil-cpp/absl/extend/internal/num_initializers.h +0 -113
- package/deps/abseil-cpp/absl/extend/internal/num_initializers_test.cc +0 -250
- package/deps/abseil-cpp/absl/extend/internal/reflection.cc +0 -112
- package/deps/abseil-cpp/absl/extend/internal/reflection.h +0 -75
- package/deps/abseil-cpp/absl/extend/internal/tuple.h +0 -51
- package/deps/abseil-cpp/absl/flags/BUILD.bazel +0 -618
- package/deps/abseil-cpp/absl/flags/CMakeLists.txt +0 -482
- package/deps/abseil-cpp/absl/flags/commandlineflag.cc +0 -35
- package/deps/abseil-cpp/absl/flags/commandlineflag.h +0 -219
- package/deps/abseil-cpp/absl/flags/commandlineflag_test.cc +0 -236
- package/deps/abseil-cpp/absl/flags/config.h +0 -68
- package/deps/abseil-cpp/absl/flags/config_test.cc +0 -61
- package/deps/abseil-cpp/absl/flags/declare.h +0 -77
- package/deps/abseil-cpp/absl/flags/flag.h +0 -307
- package/deps/abseil-cpp/absl/flags/flag_benchmark.cc +0 -251
- package/deps/abseil-cpp/absl/flags/flag_benchmark.lds +0 -13
- package/deps/abseil-cpp/absl/flags/flag_test.cc +0 -1381
- package/deps/abseil-cpp/absl/flags/flag_test_defs.cc +0 -24
- package/deps/abseil-cpp/absl/flags/internal/commandlineflag.cc +0 -26
- package/deps/abseil-cpp/absl/flags/internal/commandlineflag.h +0 -68
- package/deps/abseil-cpp/absl/flags/internal/flag.cc +0 -712
- package/deps/abseil-cpp/absl/flags/internal/flag.h +0 -969
- package/deps/abseil-cpp/absl/flags/internal/parse.h +0 -70
- package/deps/abseil-cpp/absl/flags/internal/path_util.h +0 -62
- package/deps/abseil-cpp/absl/flags/internal/path_util_test.cc +0 -46
- package/deps/abseil-cpp/absl/flags/internal/private_handle_accessor.cc +0 -69
- package/deps/abseil-cpp/absl/flags/internal/private_handle_accessor.h +0 -64
- package/deps/abseil-cpp/absl/flags/internal/program_name.cc +0 -61
- package/deps/abseil-cpp/absl/flags/internal/program_name.h +0 -50
- package/deps/abseil-cpp/absl/flags/internal/program_name_test.cc +0 -61
- package/deps/abseil-cpp/absl/flags/internal/registry.h +0 -98
- package/deps/abseil-cpp/absl/flags/internal/sequence_lock.h +0 -187
- package/deps/abseil-cpp/absl/flags/internal/sequence_lock_test.cc +0 -169
- package/deps/abseil-cpp/absl/flags/internal/usage.cc +0 -558
- package/deps/abseil-cpp/absl/flags/internal/usage.h +0 -106
- package/deps/abseil-cpp/absl/flags/internal/usage_test.cc +0 -550
- package/deps/abseil-cpp/absl/flags/marshalling.cc +0 -276
- package/deps/abseil-cpp/absl/flags/marshalling.h +0 -361
- package/deps/abseil-cpp/absl/flags/marshalling_test.cc +0 -1220
- package/deps/abseil-cpp/absl/flags/parse.cc +0 -952
- package/deps/abseil-cpp/absl/flags/parse.h +0 -130
- package/deps/abseil-cpp/absl/flags/parse_test.cc +0 -1094
- package/deps/abseil-cpp/absl/flags/reflection.cc +0 -368
- package/deps/abseil-cpp/absl/flags/reflection.h +0 -90
- package/deps/abseil-cpp/absl/flags/reflection_test.cc +0 -268
- package/deps/abseil-cpp/absl/flags/usage.cc +0 -66
- package/deps/abseil-cpp/absl/flags/usage.h +0 -43
- package/deps/abseil-cpp/absl/flags/usage_config.cc +0 -170
- package/deps/abseil-cpp/absl/flags/usage_config.h +0 -135
- package/deps/abseil-cpp/absl/flags/usage_config_test.cc +0 -205
- package/deps/abseil-cpp/absl/functional/BUILD.bazel +0 -173
- package/deps/abseil-cpp/absl/functional/CMakeLists.txt +0 -140
- package/deps/abseil-cpp/absl/functional/any_invocable.h +0 -336
- package/deps/abseil-cpp/absl/functional/any_invocable_test.cc +0 -1687
- package/deps/abseil-cpp/absl/functional/bind_front.h +0 -200
- package/deps/abseil-cpp/absl/functional/bind_front_test.cc +0 -227
- package/deps/abseil-cpp/absl/functional/function_ref.h +0 -249
- package/deps/abseil-cpp/absl/functional/function_ref_test.cc +0 -416
- package/deps/abseil-cpp/absl/functional/function_type_benchmark.cc +0 -176
- package/deps/abseil-cpp/absl/functional/internal/any_invocable.h +0 -787
- package/deps/abseil-cpp/absl/functional/internal/front_binder.h +0 -93
- package/deps/abseil-cpp/absl/functional/internal/function_ref.h +0 -151
- package/deps/abseil-cpp/absl/functional/overload.h +0 -72
- package/deps/abseil-cpp/absl/functional/overload_test.cc +0 -207
- package/deps/abseil-cpp/absl/hash/BUILD.bazel +0 -220
- package/deps/abseil-cpp/absl/hash/CMakeLists.txt +0 -179
- package/deps/abseil-cpp/absl/hash/hash.h +0 -466
- package/deps/abseil-cpp/absl/hash/hash_benchmark.cc +0 -398
- package/deps/abseil-cpp/absl/hash/hash_instantiated_test.cc +0 -224
- package/deps/abseil-cpp/absl/hash/hash_test.cc +0 -1320
- package/deps/abseil-cpp/absl/hash/hash_testing.h +0 -380
- package/deps/abseil-cpp/absl/hash/internal/city.cc +0 -337
- package/deps/abseil-cpp/absl/hash/internal/city.h +0 -78
- package/deps/abseil-cpp/absl/hash/internal/city_test.cc +0 -597
- package/deps/abseil-cpp/absl/hash/internal/hash.cc +0 -430
- package/deps/abseil-cpp/absl/hash/internal/hash.h +0 -1563
- package/deps/abseil-cpp/absl/hash/internal/hash_test.h +0 -87
- package/deps/abseil-cpp/absl/hash/internal/low_level_hash_test.cc +0 -509
- package/deps/abseil-cpp/absl/hash/internal/print_hash_of.cc +0 -23
- package/deps/abseil-cpp/absl/hash/internal/spy_hash_state.h +0 -286
- package/deps/abseil-cpp/absl/hash/internal/weakly_mixed_integer.h +0 -38
- package/deps/abseil-cpp/absl/log/BUILD.bazel +0 -686
- package/deps/abseil-cpp/absl/log/CMakeLists.txt +0 -1239
- package/deps/abseil-cpp/absl/log/absl_check.h +0 -117
- package/deps/abseil-cpp/absl/log/absl_check_test.cc +0 -58
- package/deps/abseil-cpp/absl/log/absl_log.h +0 -115
- package/deps/abseil-cpp/absl/log/absl_log_basic_test.cc +0 -22
- package/deps/abseil-cpp/absl/log/absl_vlog_is_on.h +0 -95
- package/deps/abseil-cpp/absl/log/check.h +0 -210
- package/deps/abseil-cpp/absl/log/check_test.cc +0 -58
- package/deps/abseil-cpp/absl/log/check_test_impl.inc +0 -1035
- package/deps/abseil-cpp/absl/log/die_if_null.cc +0 -34
- package/deps/abseil-cpp/absl/log/die_if_null.h +0 -97
- package/deps/abseil-cpp/absl/log/die_if_null_test.cc +0 -107
- package/deps/abseil-cpp/absl/log/flags.cc +0 -143
- package/deps/abseil-cpp/absl/log/flags.h +0 -43
- package/deps/abseil-cpp/absl/log/flags_test.cc +0 -195
- package/deps/abseil-cpp/absl/log/globals.cc +0 -178
- package/deps/abseil-cpp/absl/log/globals.h +0 -230
- package/deps/abseil-cpp/absl/log/globals_test.cc +0 -156
- package/deps/abseil-cpp/absl/log/initialize.cc +0 -38
- package/deps/abseil-cpp/absl/log/initialize.h +0 -45
- package/deps/abseil-cpp/absl/log/internal/BUILD.bazel +0 -581
- package/deps/abseil-cpp/absl/log/internal/append_truncated.h +0 -75
- package/deps/abseil-cpp/absl/log/internal/check_impl.h +0 -151
- package/deps/abseil-cpp/absl/log/internal/check_op.cc +0 -147
- package/deps/abseil-cpp/absl/log/internal/check_op.h +0 -565
- package/deps/abseil-cpp/absl/log/internal/conditions.cc +0 -85
- package/deps/abseil-cpp/absl/log/internal/conditions.h +0 -247
- package/deps/abseil-cpp/absl/log/internal/config.h +0 -45
- package/deps/abseil-cpp/absl/log/internal/container.h +0 -312
- package/deps/abseil-cpp/absl/log/internal/container_test.cc +0 -254
- package/deps/abseil-cpp/absl/log/internal/flags.h +0 -59
- package/deps/abseil-cpp/absl/log/internal/fnmatch.cc +0 -73
- package/deps/abseil-cpp/absl/log/internal/fnmatch.h +0 -35
- package/deps/abseil-cpp/absl/log/internal/fnmatch_benchmark.cc +0 -29
- package/deps/abseil-cpp/absl/log/internal/fnmatch_test.cc +0 -60
- package/deps/abseil-cpp/absl/log/internal/globals.cc +0 -145
- package/deps/abseil-cpp/absl/log/internal/globals.h +0 -101
- package/deps/abseil-cpp/absl/log/internal/log_format.cc +0 -205
- package/deps/abseil-cpp/absl/log/internal/log_format.h +0 -78
- package/deps/abseil-cpp/absl/log/internal/log_impl.h +0 -280
- package/deps/abseil-cpp/absl/log/internal/log_message.cc +0 -787
- package/deps/abseil-cpp/absl/log/internal/log_message.h +0 -455
- package/deps/abseil-cpp/absl/log/internal/log_sink_set.cc +0 -296
- package/deps/abseil-cpp/absl/log/internal/log_sink_set.h +0 -54
- package/deps/abseil-cpp/absl/log/internal/nullguard.cc +0 -35
- package/deps/abseil-cpp/absl/log/internal/nullguard.h +0 -88
- package/deps/abseil-cpp/absl/log/internal/nullstream.h +0 -128
- package/deps/abseil-cpp/absl/log/internal/proto.cc +0 -218
- package/deps/abseil-cpp/absl/log/internal/proto.h +0 -298
- package/deps/abseil-cpp/absl/log/internal/stderr_log_sink_test.cc +0 -105
- package/deps/abseil-cpp/absl/log/internal/strip.h +0 -99
- package/deps/abseil-cpp/absl/log/internal/structured.h +0 -160
- package/deps/abseil-cpp/absl/log/internal/structured_proto.cc +0 -115
- package/deps/abseil-cpp/absl/log/internal/structured_proto.h +0 -107
- package/deps/abseil-cpp/absl/log/internal/structured_proto_test.cc +0 -120
- package/deps/abseil-cpp/absl/log/internal/test_actions.cc +0 -75
- package/deps/abseil-cpp/absl/log/internal/test_actions.h +0 -90
- package/deps/abseil-cpp/absl/log/internal/test_helpers.cc +0 -82
- package/deps/abseil-cpp/absl/log/internal/test_helpers.h +0 -71
- package/deps/abseil-cpp/absl/log/internal/test_matchers.cc +0 -216
- package/deps/abseil-cpp/absl/log/internal/test_matchers.h +0 -94
- package/deps/abseil-cpp/absl/log/internal/vlog_config.cc +0 -347
- package/deps/abseil-cpp/absl/log/internal/vlog_config.h +0 -164
- package/deps/abseil-cpp/absl/log/internal/vlog_config_benchmark.cc +0 -187
- package/deps/abseil-cpp/absl/log/internal/voidify.h +0 -50
- package/deps/abseil-cpp/absl/log/log.h +0 -378
- package/deps/abseil-cpp/absl/log/log_basic_test.cc +0 -22
- package/deps/abseil-cpp/absl/log/log_basic_test_impl.inc +0 -654
- package/deps/abseil-cpp/absl/log/log_benchmark.cc +0 -164
- package/deps/abseil-cpp/absl/log/log_entry.cc +0 -263
- package/deps/abseil-cpp/absl/log/log_entry.h +0 -223
- package/deps/abseil-cpp/absl/log/log_entry_test.cc +0 -468
- package/deps/abseil-cpp/absl/log/log_format_test.cc +0 -2261
- package/deps/abseil-cpp/absl/log/log_macro_hygiene_test.cc +0 -187
- package/deps/abseil-cpp/absl/log/log_modifier_methods_test.cc +0 -244
- package/deps/abseil-cpp/absl/log/log_sink.cc +0 -23
- package/deps/abseil-cpp/absl/log/log_sink.h +0 -71
- package/deps/abseil-cpp/absl/log/log_sink_registry.h +0 -64
- package/deps/abseil-cpp/absl/log/log_sink_test.cc +0 -418
- package/deps/abseil-cpp/absl/log/log_streamer.h +0 -181
- package/deps/abseil-cpp/absl/log/log_streamer_test.cc +0 -451
- package/deps/abseil-cpp/absl/log/scoped_mock_log.cc +0 -86
- package/deps/abseil-cpp/absl/log/scoped_mock_log.h +0 -203
- package/deps/abseil-cpp/absl/log/scoped_mock_log_test.cc +0 -295
- package/deps/abseil-cpp/absl/log/stripping_test.cc +0 -502
- package/deps/abseil-cpp/absl/log/structured.h +0 -75
- package/deps/abseil-cpp/absl/log/structured_test.cc +0 -64
- package/deps/abseil-cpp/absl/log/vlog_is_on.h +0 -74
- package/deps/abseil-cpp/absl/log/vlog_is_on_test.cc +0 -233
- package/deps/abseil-cpp/absl/memory/BUILD.bazel +0 -62
- package/deps/abseil-cpp/absl/memory/CMakeLists.txt +0 -41
- package/deps/abseil-cpp/absl/memory/memory.h +0 -278
- package/deps/abseil-cpp/absl/memory/memory_test.cc +0 -222
- package/deps/abseil-cpp/absl/meta/BUILD.bazel +0 -112
- package/deps/abseil-cpp/absl/meta/CMakeLists.txt +0 -100
- package/deps/abseil-cpp/absl/meta/internal/constexpr_testing.h +0 -73
- package/deps/abseil-cpp/absl/meta/internal/constexpr_testing_test.cc +0 -40
- package/deps/abseil-cpp/absl/meta/internal/requires.h +0 -67
- package/deps/abseil-cpp/absl/meta/internal/requires_test.cc +0 -66
- package/deps/abseil-cpp/absl/meta/type_traits.h +0 -582
- package/deps/abseil-cpp/absl/meta/type_traits_test.cc +0 -378
- package/deps/abseil-cpp/absl/numeric/BUILD.bazel +0 -145
- package/deps/abseil-cpp/absl/numeric/CMakeLists.txt +0 -104
- package/deps/abseil-cpp/absl/numeric/bits.h +0 -262
- package/deps/abseil-cpp/absl/numeric/bits_benchmark.cc +0 -73
- package/deps/abseil-cpp/absl/numeric/bits_test.cc +0 -724
- package/deps/abseil-cpp/absl/numeric/int128.cc +0 -344
- package/deps/abseil-cpp/absl/numeric/int128.h +0 -1224
- package/deps/abseil-cpp/absl/numeric/int128_benchmark.cc +0 -281
- package/deps/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +0 -303
- package/deps/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +0 -347
- package/deps/abseil-cpp/absl/numeric/int128_stream_test.cc +0 -1400
- package/deps/abseil-cpp/absl/numeric/int128_test.cc +0 -1407
- package/deps/abseil-cpp/absl/numeric/internal/bits.h +0 -394
- package/deps/abseil-cpp/absl/numeric/internal/representation.h +0 -55
- package/deps/abseil-cpp/absl/profiling/BUILD.bazel +0 -188
- package/deps/abseil-cpp/absl/profiling/CMakeLists.txt +0 -132
- package/deps/abseil-cpp/absl/profiling/hashtable.cc +0 -135
- package/deps/abseil-cpp/absl/profiling/hashtable.h +0 -40
- package/deps/abseil-cpp/absl/profiling/internal/exponential_biased.cc +0 -93
- package/deps/abseil-cpp/absl/profiling/internal/exponential_biased.h +0 -130
- package/deps/abseil-cpp/absl/profiling/internal/exponential_biased_test.cc +0 -203
- package/deps/abseil-cpp/absl/profiling/internal/periodic_sampler.cc +0 -53
- package/deps/abseil-cpp/absl/profiling/internal/periodic_sampler.h +0 -211
- package/deps/abseil-cpp/absl/profiling/internal/periodic_sampler_benchmark.cc +0 -79
- package/deps/abseil-cpp/absl/profiling/internal/periodic_sampler_test.cc +0 -177
- package/deps/abseil-cpp/absl/profiling/internal/profile_builder.cc +0 -463
- package/deps/abseil-cpp/absl/profiling/internal/profile_builder.h +0 -161
- package/deps/abseil-cpp/absl/profiling/internal/sample_recorder.h +0 -253
- package/deps/abseil-cpp/absl/profiling/internal/sample_recorder_test.cc +0 -188
- package/deps/abseil-cpp/absl/random/BUILD.bazel +0 -550
- package/deps/abseil-cpp/absl/random/CMakeLists.txt +0 -1250
- package/deps/abseil-cpp/absl/random/benchmarks.cc +0 -376
- package/deps/abseil-cpp/absl/random/bernoulli_distribution.h +0 -202
- package/deps/abseil-cpp/absl/random/bernoulli_distribution_test.cc +0 -217
- package/deps/abseil-cpp/absl/random/beta_distribution.h +0 -429
- package/deps/abseil-cpp/absl/random/beta_distribution_test.cc +0 -615
- package/deps/abseil-cpp/absl/random/bit_gen_ref.h +0 -187
- package/deps/abseil-cpp/absl/random/bit_gen_ref_test.cc +0 -107
- package/deps/abseil-cpp/absl/random/discrete_distribution.cc +0 -108
- package/deps/abseil-cpp/absl/random/discrete_distribution.h +0 -249
- package/deps/abseil-cpp/absl/random/discrete_distribution_test.cc +0 -251
- package/deps/abseil-cpp/absl/random/distributions.h +0 -450
- package/deps/abseil-cpp/absl/random/distributions_test.cc +0 -516
- package/deps/abseil-cpp/absl/random/examples_test.cc +0 -98
- package/deps/abseil-cpp/absl/random/exponential_distribution.h +0 -166
- package/deps/abseil-cpp/absl/random/exponential_distribution_test.cc +0 -426
- package/deps/abseil-cpp/absl/random/gaussian_distribution.cc +0 -104
- package/deps/abseil-cpp/absl/random/gaussian_distribution.h +0 -276
- package/deps/abseil-cpp/absl/random/gaussian_distribution_test.cc +0 -561
- package/deps/abseil-cpp/absl/random/generators_test.cc +0 -185
- package/deps/abseil-cpp/absl/random/internal/BUILD.bazel +0 -863
- package/deps/abseil-cpp/absl/random/internal/chi_square.cc +0 -230
- package/deps/abseil-cpp/absl/random/internal/chi_square.h +0 -89
- package/deps/abseil-cpp/absl/random/internal/chi_square_test.cc +0 -364
- package/deps/abseil-cpp/absl/random/internal/distribution_caller.h +0 -96
- package/deps/abseil-cpp/absl/random/internal/distribution_test_util.cc +0 -418
- package/deps/abseil-cpp/absl/random/internal/distribution_test_util.h +0 -113
- package/deps/abseil-cpp/absl/random/internal/distribution_test_util_test.cc +0 -193
- package/deps/abseil-cpp/absl/random/internal/entropy_pool.cc +0 -185
- package/deps/abseil-cpp/absl/random/internal/entropy_pool.h +0 -35
- package/deps/abseil-cpp/absl/random/internal/entropy_pool_test.cc +0 -119
- package/deps/abseil-cpp/absl/random/internal/explicit_seed_seq.h +0 -92
- package/deps/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc +0 -241
- package/deps/abseil-cpp/absl/random/internal/fast_uniform_bits.h +0 -271
- package/deps/abseil-cpp/absl/random/internal/fast_uniform_bits_test.cc +0 -336
- package/deps/abseil-cpp/absl/random/internal/fastmath.h +0 -57
- package/deps/abseil-cpp/absl/random/internal/fastmath_test.cc +0 -95
- package/deps/abseil-cpp/absl/random/internal/gaussian_distribution_gentables.cc +0 -142
- package/deps/abseil-cpp/absl/random/internal/generate_real.h +0 -144
- package/deps/abseil-cpp/absl/random/internal/generate_real_test.cc +0 -496
- package/deps/abseil-cpp/absl/random/internal/iostream_state_saver.h +0 -248
- package/deps/abseil-cpp/absl/random/internal/iostream_state_saver_test.cc +0 -373
- package/deps/abseil-cpp/absl/random/internal/mock_helpers.h +0 -160
- package/deps/abseil-cpp/absl/random/internal/mock_overload_set.h +0 -122
- package/deps/abseil-cpp/absl/random/internal/mock_validators.h +0 -98
- package/deps/abseil-cpp/absl/random/internal/nanobenchmark.cc +0 -804
- package/deps/abseil-cpp/absl/random/internal/nanobenchmark.h +0 -172
- package/deps/abseil-cpp/absl/random/internal/nanobenchmark_test.cc +0 -79
- package/deps/abseil-cpp/absl/random/internal/nonsecure_base.h +0 -160
- package/deps/abseil-cpp/absl/random/internal/nonsecure_base_test.cc +0 -267
- package/deps/abseil-cpp/absl/random/internal/pcg_engine.h +0 -287
- package/deps/abseil-cpp/absl/random/internal/pcg_engine_test.cc +0 -638
- package/deps/abseil-cpp/absl/random/internal/platform.h +0 -158
- package/deps/abseil-cpp/absl/random/internal/randen.cc +0 -91
- package/deps/abseil-cpp/absl/random/internal/randen.h +0 -96
- package/deps/abseil-cpp/absl/random/internal/randen_benchmarks.cc +0 -177
- package/deps/abseil-cpp/absl/random/internal/randen_detect.cc +0 -280
- package/deps/abseil-cpp/absl/random/internal/randen_detect.h +0 -33
- package/deps/abseil-cpp/absl/random/internal/randen_engine.h +0 -265
- package/deps/abseil-cpp/absl/random/internal/randen_engine_test.cc +0 -654
- package/deps/abseil-cpp/absl/random/internal/randen_hwaes.cc +0 -526
- package/deps/abseil-cpp/absl/random/internal/randen_hwaes.h +0 -50
- package/deps/abseil-cpp/absl/random/internal/randen_hwaes_test.cc +0 -99
- package/deps/abseil-cpp/absl/random/internal/randen_round_keys.cc +0 -462
- package/deps/abseil-cpp/absl/random/internal/randen_slow.cc +0 -471
- package/deps/abseil-cpp/absl/random/internal/randen_slow.h +0 -40
- package/deps/abseil-cpp/absl/random/internal/randen_slow_test.cc +0 -61
- package/deps/abseil-cpp/absl/random/internal/randen_test.cc +0 -75
- package/deps/abseil-cpp/absl/random/internal/randen_traits.h +0 -88
- package/deps/abseil-cpp/absl/random/internal/salted_seed_seq.h +0 -165
- package/deps/abseil-cpp/absl/random/internal/salted_seed_seq_test.cc +0 -172
- package/deps/abseil-cpp/absl/random/internal/seed_material.cc +0 -249
- package/deps/abseil-cpp/absl/random/internal/seed_material.h +0 -104
- package/deps/abseil-cpp/absl/random/internal/seed_material_test.cc +0 -205
- package/deps/abseil-cpp/absl/random/internal/sequence_urbg.h +0 -60
- package/deps/abseil-cpp/absl/random/internal/traits.h +0 -149
- package/deps/abseil-cpp/absl/random/internal/traits_test.cc +0 -123
- package/deps/abseil-cpp/absl/random/internal/uniform_helper.h +0 -244
- package/deps/abseil-cpp/absl/random/internal/uniform_helper_test.cc +0 -279
- package/deps/abseil-cpp/absl/random/internal/wide_multiply.h +0 -95
- package/deps/abseil-cpp/absl/random/internal/wide_multiply_test.cc +0 -119
- package/deps/abseil-cpp/absl/random/log_uniform_int_distribution.h +0 -253
- package/deps/abseil-cpp/absl/random/log_uniform_int_distribution_test.cc +0 -277
- package/deps/abseil-cpp/absl/random/mock_distributions.h +0 -269
- package/deps/abseil-cpp/absl/random/mock_distributions_test.cc +0 -281
- package/deps/abseil-cpp/absl/random/mocking_bit_gen.h +0 -237
- package/deps/abseil-cpp/absl/random/mocking_bit_gen_test.cc +0 -403
- package/deps/abseil-cpp/absl/random/poisson_distribution.h +0 -262
- package/deps/abseil-cpp/absl/random/poisson_distribution_test.cc +0 -569
- package/deps/abseil-cpp/absl/random/random.h +0 -224
- package/deps/abseil-cpp/absl/random/seed_gen_exception.cc +0 -45
- package/deps/abseil-cpp/absl/random/seed_gen_exception.h +0 -55
- package/deps/abseil-cpp/absl/random/seed_sequences.cc +0 -33
- package/deps/abseil-cpp/absl/random/seed_sequences.h +0 -112
- package/deps/abseil-cpp/absl/random/seed_sequences_test.cc +0 -126
- package/deps/abseil-cpp/absl/random/uniform_int_distribution.h +0 -276
- package/deps/abseil-cpp/absl/random/uniform_int_distribution_test.cc +0 -259
- package/deps/abseil-cpp/absl/random/uniform_real_distribution.h +0 -204
- package/deps/abseil-cpp/absl/random/uniform_real_distribution_test.cc +0 -394
- package/deps/abseil-cpp/absl/random/zipf_distribution.h +0 -273
- package/deps/abseil-cpp/absl/random/zipf_distribution_test.cc +0 -423
- package/deps/abseil-cpp/absl/status/BUILD.bazel +0 -211
- package/deps/abseil-cpp/absl/status/CMakeLists.txt +0 -159
- package/deps/abseil-cpp/absl/status/internal/status_internal.cc +0 -251
- package/deps/abseil-cpp/absl/status/internal/status_internal.h +0 -133
- package/deps/abseil-cpp/absl/status/internal/status_matchers.cc +0 -69
- package/deps/abseil-cpp/absl/status/internal/status_matchers.h +0 -246
- package/deps/abseil-cpp/absl/status/internal/statusor_internal.h +0 -657
- package/deps/abseil-cpp/absl/status/status.cc +0 -421
- package/deps/abseil-cpp/absl/status/status.h +0 -948
- package/deps/abseil-cpp/absl/status/status_benchmark.cc +0 -37
- package/deps/abseil-cpp/absl/status/status_matchers.h +0 -166
- package/deps/abseil-cpp/absl/status/status_matchers_test.cc +0 -211
- package/deps/abseil-cpp/absl/status/status_payload_printer.cc +0 -36
- package/deps/abseil-cpp/absl/status/status_payload_printer.h +0 -52
- package/deps/abseil-cpp/absl/status/status_test.cc +0 -580
- package/deps/abseil-cpp/absl/status/statusor.cc +0 -106
- package/deps/abseil-cpp/absl/status/statusor.h +0 -743
- package/deps/abseil-cpp/absl/status/statusor_benchmark.cc +0 -480
- package/deps/abseil-cpp/absl/status/statusor_test.cc +0 -2124
- package/deps/abseil-cpp/absl/strings/BUILD.bazel +0 -1593
- package/deps/abseil-cpp/absl/strings/CMakeLists.txt +0 -1295
- package/deps/abseil-cpp/absl/strings/ascii.cc +0 -296
- package/deps/abseil-cpp/absl/strings/ascii.h +0 -289
- package/deps/abseil-cpp/absl/strings/ascii_benchmark.cc +0 -157
- package/deps/abseil-cpp/absl/strings/ascii_test.cc +0 -374
- package/deps/abseil-cpp/absl/strings/atod_manual_test.cc +0 -193
- package/deps/abseil-cpp/absl/strings/char_formatting_test.cc +0 -169
- package/deps/abseil-cpp/absl/strings/charconv.cc +0 -1442
- package/deps/abseil-cpp/absl/strings/charconv.h +0 -123
- package/deps/abseil-cpp/absl/strings/charconv_benchmark.cc +0 -203
- package/deps/abseil-cpp/absl/strings/charconv_test.cc +0 -787
- package/deps/abseil-cpp/absl/strings/charset.h +0 -163
- package/deps/abseil-cpp/absl/strings/charset_benchmark.cc +0 -57
- package/deps/abseil-cpp/absl/strings/charset_test.cc +0 -181
- package/deps/abseil-cpp/absl/strings/cord.cc +0 -1582
- package/deps/abseil-cpp/absl/strings/cord.h +0 -1763
- package/deps/abseil-cpp/absl/strings/cord_analysis.cc +0 -196
- package/deps/abseil-cpp/absl/strings/cord_analysis.h +0 -63
- package/deps/abseil-cpp/absl/strings/cord_buffer.h +0 -572
- package/deps/abseil-cpp/absl/strings/cord_buffer_test.cc +0 -322
- package/deps/abseil-cpp/absl/strings/cord_test.cc +0 -3421
- package/deps/abseil-cpp/absl/strings/cord_test_helpers.h +0 -122
- package/deps/abseil-cpp/absl/strings/cordz_test.cc +0 -468
- package/deps/abseil-cpp/absl/strings/cordz_test_helpers.h +0 -152
- package/deps/abseil-cpp/absl/strings/escaping.cc +0 -1035
- package/deps/abseil-cpp/absl/strings/escaping.h +0 -185
- package/deps/abseil-cpp/absl/strings/escaping_benchmark.cc +0 -124
- package/deps/abseil-cpp/absl/strings/escaping_test.cc +0 -760
- package/deps/abseil-cpp/absl/strings/has_absl_stringify.h +0 -64
- package/deps/abseil-cpp/absl/strings/has_absl_stringify_test.cc +0 -40
- package/deps/abseil-cpp/absl/strings/has_ostream_operator.h +0 -42
- package/deps/abseil-cpp/absl/strings/has_ostream_operator_test.cc +0 -41
- package/deps/abseil-cpp/absl/strings/internal/append_and_overwrite.h +0 -93
- package/deps/abseil-cpp/absl/strings/internal/append_and_overwrite_test.cc +0 -95
- package/deps/abseil-cpp/absl/strings/internal/charconv_bigint.cc +0 -357
- package/deps/abseil-cpp/absl/strings/internal/charconv_bigint.h +0 -433
- package/deps/abseil-cpp/absl/strings/internal/charconv_bigint_test.cc +0 -260
- package/deps/abseil-cpp/absl/strings/internal/charconv_parse.cc +0 -504
- package/deps/abseil-cpp/absl/strings/internal/charconv_parse.h +0 -99
- package/deps/abseil-cpp/absl/strings/internal/charconv_parse_test.cc +0 -357
- package/deps/abseil-cpp/absl/strings/internal/cord_data_edge.h +0 -63
- package/deps/abseil-cpp/absl/strings/internal/cord_data_edge_test.cc +0 -130
- package/deps/abseil-cpp/absl/strings/internal/cord_internal.cc +0 -70
- package/deps/abseil-cpp/absl/strings/internal/cord_internal.h +0 -942
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +0 -1237
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree.h +0 -944
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +0 -187
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +0 -267
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator_test.cc +0 -346
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +0 -69
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +0 -212
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_reader_test.cc +0 -293
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_test.cc +0 -1568
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +0 -64
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_consume.h +0 -47
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +0 -56
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_crc.h +0 -103
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_crc_test.cc +0 -130
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_flat.h +0 -195
- package/deps/abseil-cpp/absl/strings/internal/cord_rep_test_util.h +0 -205
- package/deps/abseil-cpp/absl/strings/internal/cordz_functions.cc +0 -102
- package/deps/abseil-cpp/absl/strings/internal/cordz_functions.h +0 -87
- package/deps/abseil-cpp/absl/strings/internal/cordz_functions_test.cc +0 -147
- package/deps/abseil-cpp/absl/strings/internal/cordz_handle.cc +0 -165
- package/deps/abseil-cpp/absl/strings/internal/cordz_handle.h +0 -98
- package/deps/abseil-cpp/absl/strings/internal/cordz_handle_test.cc +0 -265
- package/deps/abseil-cpp/absl/strings/internal/cordz_info.cc +0 -424
- package/deps/abseil-cpp/absl/strings/internal/cordz_info.h +0 -295
- package/deps/abseil-cpp/absl/strings/internal/cordz_info_statistics_test.cc +0 -510
- package/deps/abseil-cpp/absl/strings/internal/cordz_info_test.cc +0 -342
- package/deps/abseil-cpp/absl/strings/internal/cordz_sample_token.cc +0 -64
- package/deps/abseil-cpp/absl/strings/internal/cordz_sample_token.h +0 -97
- package/deps/abseil-cpp/absl/strings/internal/cordz_sample_token_test.cc +0 -208
- package/deps/abseil-cpp/absl/strings/internal/cordz_statistics.h +0 -88
- package/deps/abseil-cpp/absl/strings/internal/cordz_update_scope.h +0 -71
- package/deps/abseil-cpp/absl/strings/internal/cordz_update_scope_test.cc +0 -49
- package/deps/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +0 -123
- package/deps/abseil-cpp/absl/strings/internal/cordz_update_tracker_test.cc +0 -147
- package/deps/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance.cc +0 -99
- package/deps/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance.h +0 -35
- package/deps/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance_benchmark.cc +0 -56
- package/deps/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance_test.cc +0 -99
- package/deps/abseil-cpp/absl/strings/internal/escaping.cc +0 -209
- package/deps/abseil-cpp/absl/strings/internal/escaping.h +0 -59
- package/deps/abseil-cpp/absl/strings/internal/escaping_test_common.h +0 -133
- package/deps/abseil-cpp/absl/strings/internal/generic_printer.cc +0 -107
- package/deps/abseil-cpp/absl/strings/internal/generic_printer.h +0 -115
- package/deps/abseil-cpp/absl/strings/internal/generic_printer_internal.h +0 -423
- package/deps/abseil-cpp/absl/strings/internal/generic_printer_test.cc +0 -685
- package/deps/abseil-cpp/absl/strings/internal/memutil.cc +0 -48
- package/deps/abseil-cpp/absl/strings/internal/memutil.h +0 -40
- package/deps/abseil-cpp/absl/strings/internal/memutil_benchmark.cc +0 -127
- package/deps/abseil-cpp/absl/strings/internal/memutil_test.cc +0 -41
- package/deps/abseil-cpp/absl/strings/internal/numbers_test_common.h +0 -184
- package/deps/abseil-cpp/absl/strings/internal/ostringstream.cc +0 -43
- package/deps/abseil-cpp/absl/strings/internal/ostringstream.h +0 -114
- package/deps/abseil-cpp/absl/strings/internal/ostringstream_benchmark.cc +0 -105
- package/deps/abseil-cpp/absl/strings/internal/ostringstream_test.cc +0 -131
- package/deps/abseil-cpp/absl/strings/internal/pow10_helper.cc +0 -122
- package/deps/abseil-cpp/absl/strings/internal/pow10_helper.h +0 -40
- package/deps/abseil-cpp/absl/strings/internal/pow10_helper_test.cc +0 -122
- package/deps/abseil-cpp/absl/strings/internal/resize_uninitialized.h +0 -119
- package/deps/abseil-cpp/absl/strings/internal/resize_uninitialized_test.cc +0 -108
- package/deps/abseil-cpp/absl/strings/internal/stl_type_traits.h +0 -248
- package/deps/abseil-cpp/absl/strings/internal/str_format/arg.cc +0 -615
- package/deps/abseil-cpp/absl/strings/internal/str_format/arg.h +0 -661
- package/deps/abseil-cpp/absl/strings/internal/str_format/arg_test.cc +0 -162
- package/deps/abseil-cpp/absl/strings/internal/str_format/bind.cc +0 -275
- package/deps/abseil-cpp/absl/strings/internal/str_format/bind.h +0 -237
- package/deps/abseil-cpp/absl/strings/internal/str_format/bind_test.cc +0 -157
- package/deps/abseil-cpp/absl/strings/internal/str_format/checker.h +0 -98
- package/deps/abseil-cpp/absl/strings/internal/str_format/checker_test.cc +0 -176
- package/deps/abseil-cpp/absl/strings/internal/str_format/constexpr_parser.h +0 -357
- package/deps/abseil-cpp/absl/strings/internal/str_format/convert_test.cc +0 -1471
- package/deps/abseil-cpp/absl/strings/internal/str_format/extension.cc +0 -53
- package/deps/abseil-cpp/absl/strings/internal/str_format/extension.h +0 -456
- package/deps/abseil-cpp/absl/strings/internal/str_format/extension_test.cc +0 -110
- package/deps/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +0 -1945
- package/deps/abseil-cpp/absl/strings/internal/str_format/float_conversion.h +0 -37
- package/deps/abseil-cpp/absl/strings/internal/str_format/output.cc +0 -74
- package/deps/abseil-cpp/absl/strings/internal/str_format/output.h +0 -97
- package/deps/abseil-cpp/absl/strings/internal/str_format/output_test.cc +0 -79
- package/deps/abseil-cpp/absl/strings/internal/str_format/parser.cc +0 -140
- package/deps/abseil-cpp/absl/strings/internal/str_format/parser.h +0 -271
- package/deps/abseil-cpp/absl/strings/internal/str_format/parser_test.cc +0 -446
- package/deps/abseil-cpp/absl/strings/internal/str_join_internal.h +0 -341
- package/deps/abseil-cpp/absl/strings/internal/str_split_internal.h +0 -525
- package/deps/abseil-cpp/absl/strings/internal/string_constant.h +0 -67
- package/deps/abseil-cpp/absl/strings/internal/string_constant_test.cc +0 -60
- package/deps/abseil-cpp/absl/strings/internal/stringify_sink.cc +0 -28
- package/deps/abseil-cpp/absl/strings/internal/stringify_sink.h +0 -57
- package/deps/abseil-cpp/absl/strings/internal/utf8.cc +0 -148
- package/deps/abseil-cpp/absl/strings/internal/utf8.h +0 -64
- package/deps/abseil-cpp/absl/strings/internal/utf8_test.cc +0 -259
- package/deps/abseil-cpp/absl/strings/match.cc +0 -133
- package/deps/abseil-cpp/absl/strings/match.h +0 -129
- package/deps/abseil-cpp/absl/strings/match_test.cc +0 -291
- package/deps/abseil-cpp/absl/strings/numbers.cc +0 -1230
- package/deps/abseil-cpp/absl/strings/numbers.h +0 -359
- package/deps/abseil-cpp/absl/strings/numbers_benchmark.cc +0 -288
- package/deps/abseil-cpp/absl/strings/numbers_test.cc +0 -2324
- package/deps/abseil-cpp/absl/strings/resize_and_overwrite.h +0 -194
- package/deps/abseil-cpp/absl/strings/resize_and_overwrite_test.cc +0 -154
- package/deps/abseil-cpp/absl/strings/str_cat.cc +0 -247
- package/deps/abseil-cpp/absl/strings/str_cat.h +0 -633
- package/deps/abseil-cpp/absl/strings/str_cat_benchmark.cc +0 -288
- package/deps/abseil-cpp/absl/strings/str_cat_test.cc +0 -692
- package/deps/abseil-cpp/absl/strings/str_format.h +0 -887
- package/deps/abseil-cpp/absl/strings/str_format_test.cc +0 -1230
- package/deps/abseil-cpp/absl/strings/str_join.h +0 -301
- package/deps/abseil-cpp/absl/strings/str_join_benchmark.cc +0 -106
- package/deps/abseil-cpp/absl/strings/str_join_test.cc +0 -645
- package/deps/abseil-cpp/absl/strings/str_replace.cc +0 -91
- package/deps/abseil-cpp/absl/strings/str_replace.h +0 -222
- package/deps/abseil-cpp/absl/strings/str_replace_benchmark.cc +0 -121
- package/deps/abseil-cpp/absl/strings/str_replace_test.cc +0 -345
- package/deps/abseil-cpp/absl/strings/str_split.cc +0 -144
- package/deps/abseil-cpp/absl/strings/str_split.h +0 -582
- package/deps/abseil-cpp/absl/strings/str_split_benchmark.cc +0 -180
- package/deps/abseil-cpp/absl/strings/str_split_test.cc +0 -1069
- package/deps/abseil-cpp/absl/strings/string_view.h +0 -60
- package/deps/abseil-cpp/absl/strings/string_view_test.cc +0 -86
- package/deps/abseil-cpp/absl/strings/strip.h +0 -99
- package/deps/abseil-cpp/absl/strings/strip_test.cc +0 -198
- package/deps/abseil-cpp/absl/strings/substitute.cc +0 -187
- package/deps/abseil-cpp/absl/strings/substitute.h +0 -769
- package/deps/abseil-cpp/absl/strings/substitute_benchmark.cc +0 -158
- package/deps/abseil-cpp/absl/strings/substitute_test.cc +0 -288
- package/deps/abseil-cpp/absl/synchronization/BUILD.bazel +0 -410
- package/deps/abseil-cpp/absl/synchronization/CMakeLists.txt +0 -293
- package/deps/abseil-cpp/absl/synchronization/barrier.cc +0 -52
- package/deps/abseil-cpp/absl/synchronization/barrier.h +0 -79
- package/deps/abseil-cpp/absl/synchronization/barrier_test.cc +0 -75
- package/deps/abseil-cpp/absl/synchronization/blocking_counter.cc +0 -73
- package/deps/abseil-cpp/absl/synchronization/blocking_counter.h +0 -107
- package/deps/abseil-cpp/absl/synchronization/blocking_counter_benchmark.cc +0 -84
- package/deps/abseil-cpp/absl/synchronization/blocking_counter_test.cc +0 -146
- package/deps/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +0 -152
- package/deps/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +0 -56
- package/deps/abseil-cpp/absl/synchronization/internal/futex.h +0 -177
- package/deps/abseil-cpp/absl/synchronization/internal/futex_waiter.cc +0 -107
- package/deps/abseil-cpp/absl/synchronization/internal/futex_waiter.h +0 -63
- package/deps/abseil-cpp/absl/synchronization/internal/graphcycles.cc +0 -714
- package/deps/abseil-cpp/absl/synchronization/internal/graphcycles.h +0 -146
- package/deps/abseil-cpp/absl/synchronization/internal/graphcycles_benchmark.cc +0 -43
- package/deps/abseil-cpp/absl/synchronization/internal/graphcycles_test.cc +0 -483
- package/deps/abseil-cpp/absl/synchronization/internal/kernel_timeout.cc +0 -220
- package/deps/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +0 -178
- package/deps/abseil-cpp/absl/synchronization/internal/kernel_timeout_test.cc +0 -406
- package/deps/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +0 -106
- package/deps/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +0 -119
- package/deps/abseil-cpp/absl/synchronization/internal/per_thread_sem_test.cc +0 -194
- package/deps/abseil-cpp/absl/synchronization/internal/pthread_waiter.cc +0 -163
- package/deps/abseil-cpp/absl/synchronization/internal/pthread_waiter.h +0 -60
- package/deps/abseil-cpp/absl/synchronization/internal/sem_waiter.cc +0 -118
- package/deps/abseil-cpp/absl/synchronization/internal/sem_waiter.h +0 -65
- package/deps/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.cc +0 -87
- package/deps/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.h +0 -56
- package/deps/abseil-cpp/absl/synchronization/internal/thread_pool.h +0 -96
- package/deps/abseil-cpp/absl/synchronization/internal/waiter.h +0 -69
- package/deps/abseil-cpp/absl/synchronization/internal/waiter_base.cc +0 -38
- package/deps/abseil-cpp/absl/synchronization/internal/waiter_base.h +0 -90
- package/deps/abseil-cpp/absl/synchronization/internal/waiter_test.cc +0 -192
- package/deps/abseil-cpp/absl/synchronization/internal/win32_waiter.cc +0 -147
- package/deps/abseil-cpp/absl/synchronization/internal/win32_waiter.h +0 -72
- package/deps/abseil-cpp/absl/synchronization/lifetime_test.cc +0 -180
- package/deps/abseil-cpp/absl/synchronization/mutex.cc +0 -2820
- package/deps/abseil-cpp/absl/synchronization/mutex.h +0 -1352
- package/deps/abseil-cpp/absl/synchronization/mutex_benchmark.cc +0 -321
- package/deps/abseil-cpp/absl/synchronization/mutex_method_pointer_test.cc +0 -138
- package/deps/abseil-cpp/absl/synchronization/mutex_test.cc +0 -2065
- package/deps/abseil-cpp/absl/synchronization/notification.cc +0 -85
- package/deps/abseil-cpp/absl/synchronization/notification.h +0 -133
- package/deps/abseil-cpp/absl/synchronization/notification_test.cc +0 -230
- package/deps/abseil-cpp/absl/time/BUILD.bazel +0 -244
- package/deps/abseil-cpp/absl/time/CMakeLists.txt +0 -218
- package/deps/abseil-cpp/absl/time/civil_time.cc +0 -200
- package/deps/abseil-cpp/absl/time/civil_time.h +0 -589
- package/deps/abseil-cpp/absl/time/civil_time_benchmark.cc +0 -129
- package/deps/abseil-cpp/absl/time/civil_time_test.cc +0 -1351
- package/deps/abseil-cpp/absl/time/clock.cc +0 -603
- package/deps/abseil-cpp/absl/time/clock.h +0 -78
- package/deps/abseil-cpp/absl/time/clock_benchmark.cc +0 -74
- package/deps/abseil-cpp/absl/time/clock_interface.cc +0 -71
- package/deps/abseil-cpp/absl/time/clock_interface.h +0 -91
- package/deps/abseil-cpp/absl/time/clock_interface_test.cc +0 -128
- package/deps/abseil-cpp/absl/time/clock_test.cc +0 -122
- package/deps/abseil-cpp/absl/time/duration.cc +0 -918
- package/deps/abseil-cpp/absl/time/duration_benchmark.cc +0 -608
- package/deps/abseil-cpp/absl/time/duration_test.cc +0 -1901
- package/deps/abseil-cpp/absl/time/flag_test.cc +0 -147
- package/deps/abseil-cpp/absl/time/format.cc +0 -162
- package/deps/abseil-cpp/absl/time/format_benchmark.cc +0 -64
- package/deps/abseil-cpp/absl/time/format_test.cc +0 -441
- package/deps/abseil-cpp/absl/time/internal/cctz/BUILD.bazel +0 -195
- package/deps/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time.h +0 -332
- package/deps/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +0 -644
- package/deps/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +0 -460
- package/deps/abseil-cpp/absl/time/internal/cctz/include/cctz/zone_info_source.h +0 -102
- package/deps/abseil-cpp/absl/time/internal/cctz/src/cctz_benchmark.cc +0 -436
- package/deps/abseil-cpp/absl/time/internal/cctz/src/civil_time_detail.cc +0 -94
- package/deps/abseil-cpp/absl/time/internal/cctz/src/civil_time_test.cc +0 -1066
- package/deps/abseil-cpp/absl/time/internal/cctz/src/test_time_zone_names.cc +0 -515
- package/deps/abseil-cpp/absl/time/internal/cctz/src/test_time_zone_names.h +0 -33
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +0 -140
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.h +0 -52
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +0 -1068
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_format_test.cc +0 -1773
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +0 -47
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.h +0 -80
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +0 -115
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +0 -97
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +0 -1070
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +0 -128
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +0 -333
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +0 -60
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +0 -217
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup_test.cc +0 -918
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_name_win.cc +0 -186
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_name_win.h +0 -37
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.cc +0 -159
- package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.h +0 -132
- package/deps/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +0 -120
- package/deps/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +0 -116
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/README.zoneinfo +0 -38
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/version +0 -1
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Abidjan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Accra +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Addis_Ababa +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Algiers +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Asmara +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Asmera +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bamako +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bangui +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Banjul +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bissau +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Blantyre +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Brazzaville +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bujumbura +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Cairo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Casablanca +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ceuta +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Conakry +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Dakar +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Dar_es_Salaam +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Djibouti +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Douala +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/El_Aaiun +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Freetown +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Gaborone +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Harare +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Johannesburg +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Juba +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kampala +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Khartoum +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kigali +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kinshasa +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lagos +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Libreville +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lome +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Luanda +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lubumbashi +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lusaka +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Malabo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Maputo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Maseru +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Mbabane +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Mogadishu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Monrovia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Nairobi +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ndjamena +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Niamey +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Nouakchott +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ouagadougou +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Porto-Novo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Sao_Tome +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Timbuktu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Tripoli +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Tunis +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Windhoek +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Adak +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Anchorage +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Anguilla +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Antigua +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Araguaina +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Buenos_Aires +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Catamarca +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/ComodRivadavia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Cordoba +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Jujuy +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/La_Rioja +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Mendoza +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Rio_Gallegos +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Salta +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/San_Juan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/San_Luis +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Tucuman +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Ushuaia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Aruba +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Asuncion +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Atikokan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Atka +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bahia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bahia_Banderas +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Barbados +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Belem +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Belize +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Blanc-Sablon +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Boa_Vista +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bogota +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Boise +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Buenos_Aires +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cambridge_Bay +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Campo_Grande +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cancun +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Caracas +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Catamarca +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cayenne +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cayman +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Chicago +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Chihuahua +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ciudad_Juarez +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Coral_Harbour +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cordoba +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Costa_Rica +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Coyhaique +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Creston +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cuiaba +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Curacao +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Danmarkshavn +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dawson +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dawson_Creek +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Denver +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Detroit +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dominica +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Edmonton +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Eirunepe +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/El_Salvador +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ensenada +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fort_Nelson +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fort_Wayne +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fortaleza +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Glace_Bay +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Godthab +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Goose_Bay +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Grand_Turk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Grenada +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guadeloupe +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guatemala +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guayaquil +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guyana +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Halifax +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Havana +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Hermosillo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Indianapolis +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Knox +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Marengo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Petersburg +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Tell_City +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Vevay +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Vincennes +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Winamac +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indianapolis +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Inuvik +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Iqaluit +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Jamaica +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Jujuy +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Juneau +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kentucky/Louisville +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kentucky/Monticello +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Knox_IN +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kralendijk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/La_Paz +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Lima +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Los_Angeles +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Louisville +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Lower_Princes +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Maceio +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Managua +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Manaus +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Marigot +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Martinique +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Matamoros +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mazatlan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mendoza +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Menominee +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Merida +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Metlakatla +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mexico_City +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Miquelon +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Moncton +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Monterrey +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montevideo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montreal +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montserrat +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nassau +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/New_York +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nipigon +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nome +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Noronha +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/Beulah +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/Center +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/New_Salem +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nuuk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ojinaga +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Panama +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Pangnirtung +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Paramaribo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Phoenix +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Port-au-Prince +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Port_of_Spain +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Porto_Acre +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Porto_Velho +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Puerto_Rico +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Punta_Arenas +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rainy_River +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rankin_Inlet +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Recife +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Regina +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Resolute +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rio_Branco +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rosario +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santa_Isabel +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santarem +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santiago +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santo_Domingo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Sao_Paulo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Scoresbysund +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Shiprock +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Sitka +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Barthelemy +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Johns +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Kitts +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Lucia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Thomas +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Vincent +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Swift_Current +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tegucigalpa +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Thule +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Thunder_Bay +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tijuana +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Toronto +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tortola +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Vancouver +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Virgin +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Whitehorse +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Winnipeg +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Yakutat +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Yellowknife +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Casey +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Davis +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/DumontDUrville +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Macquarie +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Mawson +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/McMurdo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Palmer +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Rothera +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/South_Pole +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Syowa +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Troll +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Vostok +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Arctic/Longyearbyen +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aden +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Almaty +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Amman +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Anadyr +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aqtau +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aqtobe +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ashgabat +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ashkhabad +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Atyrau +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Baghdad +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bahrain +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Baku +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bangkok +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Barnaul +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Beirut +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bishkek +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Brunei +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Calcutta +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chita +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Choibalsan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chongqing +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chungking +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Colombo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dacca +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Damascus +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dhaka +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dili +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dubai +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dushanbe +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Famagusta +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Gaza +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Harbin +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hebron +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ho_Chi_Minh +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hong_Kong +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hovd +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Irkutsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Istanbul +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jakarta +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jayapura +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jerusalem +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kabul +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kamchatka +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Karachi +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kashgar +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kathmandu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Katmandu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Khandyga +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kolkata +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Krasnoyarsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuala_Lumpur +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuching +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuwait +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Macao +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Macau +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Magadan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Makassar +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Manila +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Muscat +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Nicosia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Novokuznetsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Novosibirsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Omsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Oral +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Phnom_Penh +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Pontianak +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Pyongyang +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qatar +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qostanay +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qyzylorda +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Rangoon +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Riyadh +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Saigon +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Sakhalin +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Samarkand +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Seoul +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Shanghai +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Singapore +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Srednekolymsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Taipei +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tashkent +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tbilisi +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tehran +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tel_Aviv +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Thimbu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Thimphu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tokyo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tomsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ujung_Pandang +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ulaanbaatar +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ulan_Bator +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Urumqi +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ust-Nera +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Vientiane +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Vladivostok +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yakutsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yangon +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yekaterinburg +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yerevan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Azores +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Bermuda +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Canary +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Cape_Verde +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Faeroe +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Faroe +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Jan_Mayen +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Madeira +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Reykjavik +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/South_Georgia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/St_Helena +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Stanley +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/ACT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Adelaide +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Brisbane +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Broken_Hill +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Canberra +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Currie +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Darwin +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Eucla +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Hobart +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/LHI +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Lindeman +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Lord_Howe +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Melbourne +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/NSW +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/North +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Perth +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Queensland +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/South +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Sydney +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Tasmania +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Victoria +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/West +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Yancowinna +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/Acre +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/DeNoronha +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/East +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/West +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/CET +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/CST6CDT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Atlantic +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Central +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Eastern +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Mountain +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Newfoundland +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Pacific +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Saskatchewan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Yukon +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Chile/Continental +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Chile/EasterIsland +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Cuba +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EET +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EST +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EST5EDT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Egypt +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Eire +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+0 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+1 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+10 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+11 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+12 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+2 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+3 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+4 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+5 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+6 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+7 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+8 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+9 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-0 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-1 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-10 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-11 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-12 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-13 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-14 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-2 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-3 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-4 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-5 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-6 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-7 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-8 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-9 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT0 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Greenwich +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/UCT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/UTC +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Universal +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Zulu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Amsterdam +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Andorra +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Astrakhan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Athens +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Belfast +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Belgrade +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Berlin +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Bratislava +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Brussels +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Bucharest +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Budapest +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Busingen +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Chisinau +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Copenhagen +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Dublin +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Gibraltar +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Guernsey +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Helsinki +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Isle_of_Man +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Istanbul +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Jersey +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kaliningrad +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kiev +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kirov +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kyiv +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Lisbon +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Ljubljana +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/London +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Luxembourg +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Madrid +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Malta +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Mariehamn +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Minsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Monaco +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Moscow +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Nicosia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Oslo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Paris +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Podgorica +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Prague +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Riga +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Rome +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Samara +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/San_Marino +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Sarajevo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Saratov +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Simferopol +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Skopje +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Sofia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Stockholm +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tallinn +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tirane +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tiraspol +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Ulyanovsk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Uzhgorod +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vaduz +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vatican +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vienna +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vilnius +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Volgograd +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Warsaw +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zagreb +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zaporozhye +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zurich +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Factory +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GB +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GB-Eire +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT+0 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT-0 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT0 +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Greenwich +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/HST +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Hongkong +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Iceland +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Antananarivo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Chagos +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Christmas +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Cocos +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Comoro +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Kerguelen +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mahe +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Maldives +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mauritius +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mayotte +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Reunion +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Iran +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Israel +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Jamaica +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Japan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Kwajalein +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Libya +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MET +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MST +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MST7MDT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/BajaNorte +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/BajaSur +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/General +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/NZ +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/NZ-CHAT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Navajo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/PRC +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/PST8PDT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Apia +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Auckland +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Bougainville +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Chatham +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Chuuk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Easter +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Efate +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Enderbury +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Fakaofo +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Fiji +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Funafuti +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Galapagos +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Gambier +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Guadalcanal +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Guam +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Honolulu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Johnston +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kanton +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kiritimati +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kosrae +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kwajalein +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Majuro +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Marquesas +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Midway +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Nauru +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Niue +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Norfolk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Noumea +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pago_Pago +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Palau +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pitcairn +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pohnpei +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Ponape +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Port_Moresby +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Rarotonga +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Saipan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Samoa +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tahiti +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tarawa +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tongatapu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Truk +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Wake +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Wallis +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Yap +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Poland +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Portugal +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/ROC +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/ROK +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Singapore +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Turkey +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/UCT +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Alaska +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Aleutian +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Arizona +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Central +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/East-Indiana +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Eastern +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Hawaii +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Indiana-Starke +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Michigan +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Mountain +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Pacific +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Samoa +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/UTC +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Universal +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/W-SU +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/WET +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Zulu +0 -0
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/iso3166.tab +0 -279
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/zone1970.tab +0 -375
- package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/zonenow.tab +0 -296
- package/deps/abseil-cpp/absl/time/internal/get_current_time_chrono.inc +0 -31
- package/deps/abseil-cpp/absl/time/internal/get_current_time_posix.inc +0 -24
- package/deps/abseil-cpp/absl/time/internal/test_util.cc +0 -32
- package/deps/abseil-cpp/absl/time/internal/test_util.h +0 -33
- package/deps/abseil-cpp/absl/time/simulated_clock.cc +0 -225
- package/deps/abseil-cpp/absl/time/simulated_clock.h +0 -108
- package/deps/abseil-cpp/absl/time/simulated_clock_test.cc +0 -614
- package/deps/abseil-cpp/absl/time/time.cc +0 -507
- package/deps/abseil-cpp/absl/time/time.h +0 -1926
- package/deps/abseil-cpp/absl/time/time_benchmark.cc +0 -321
- package/deps/abseil-cpp/absl/time/time_test.cc +0 -1365
- package/deps/abseil-cpp/absl/time/time_zone_test.cc +0 -97
- package/deps/abseil-cpp/absl/types/BUILD.bazel +0 -166
- package/deps/abseil-cpp/absl/types/CMakeLists.txt +0 -179
- package/deps/abseil-cpp/absl/types/any.h +0 -44
- package/deps/abseil-cpp/absl/types/compare.h +0 -506
- package/deps/abseil-cpp/absl/types/compare_test.cc +0 -300
- package/deps/abseil-cpp/absl/types/internal/span.h +0 -141
- package/deps/abseil-cpp/absl/types/optional.h +0 -41
- package/deps/abseil-cpp/absl/types/span.h +0 -830
- package/deps/abseil-cpp/absl/types/span_test.cc +0 -915
- package/deps/abseil-cpp/absl/types/variant.h +0 -82
- package/deps/abseil-cpp/absl/types/variant_test.cc +0 -164
- package/deps/abseil-cpp/absl/utility/BUILD.bazel +0 -46
- package/deps/abseil-cpp/absl/utility/CMakeLists.txt +0 -28
- package/deps/abseil-cpp/absl/utility/utility.h +0 -68
- package/deps/abseil-cpp/ci/absl_alternate_options.h +0 -28
- package/deps/abseil-cpp/ci/cmake_common.sh +0 -19
- package/deps/abseil-cpp/ci/cmake_install_test.sh +0 -64
- package/deps/abseil-cpp/ci/linux_arm_clang-latest_libcxx_bazel.sh +0 -106
- package/deps/abseil-cpp/ci/linux_clang-latest_libcxx_asan_bazel.sh +0 -114
- package/deps/abseil-cpp/ci/linux_clang-latest_libcxx_bazel.sh +0 -107
- package/deps/abseil-cpp/ci/linux_clang-latest_libcxx_tsan_bazel.sh +0 -106
- package/deps/abseil-cpp/ci/linux_clang-latest_libstdcxx_bazel.sh +0 -104
- package/deps/abseil-cpp/ci/linux_docker_containers.sh +0 -22
- package/deps/abseil-cpp/ci/linux_gcc-floor_libstdcxx_bazel.sh +0 -100
- package/deps/abseil-cpp/ci/linux_gcc-latest_libstdcxx_bazel.sh +0 -105
- package/deps/abseil-cpp/ci/linux_gcc-latest_libstdcxx_cmake.sh +0 -85
- package/deps/abseil-cpp/ci/linux_gcc_alpine_cmake.sh +0 -85
- package/deps/abseil-cpp/ci/macos_xcode_bazel.sh +0 -70
- package/deps/abseil-cpp/ci/macos_xcode_cmake.sh +0 -78
- package/deps/abseil-cpp/ci/windows_clangcl_bazel.bat +0 -70
- package/deps/abseil-cpp/ci/windows_msvc_bazel.bat +0 -61
- package/deps/abseil-cpp/ci/windows_msvc_cmake.bat +0 -69
- package/deps/abseil-cpp/conanfile.py +0 -51
- package/deps/abseil-cpp/create_lts.py +0 -139
- package/deps/re2/.bazelrc +0 -20
- package/deps/re2/.bcr/metadata.template.json +0 -16
- package/deps/re2/.bcr/presubmit.yml +0 -57
- package/deps/re2/.bcr/source.template.json +0 -5
- package/deps/re2/BUILD.bazel +0 -463
- package/deps/re2/CMakeLists.txt +0 -283
- package/deps/re2/LICENSE +0 -27
- package/deps/re2/MODULE.bazel +0 -29
- package/deps/re2/Makefile +0 -408
- package/deps/re2/WORKSPACE.bazel +0 -7
- package/deps/re2/WORKSPACE.bzlmod +0 -7
- package/deps/re2/app/BUILD.bazel +0 -24
- package/deps/re2/app/_re2.cc +0 -94
- package/deps/re2/app/_re2.d.ts +0 -23
- package/deps/re2/app/app.ts +0 -111
- package/deps/re2/app/build.sh +0 -32
- package/deps/re2/app/index.html +0 -5
- package/deps/re2/app/package.json +0 -14
- package/deps/re2/app/rollup.config.js +0 -28
- package/deps/re2/app/tsconfig.json +0 -17
- package/deps/re2/benchlog/benchplot.py +0 -98
- package/deps/re2/benchlog/mktable +0 -155
- package/deps/re2/doc/mksyntaxgo +0 -42
- package/deps/re2/doc/mksyntaxhtml +0 -42
- package/deps/re2/doc/mksyntaxwiki +0 -36
- package/deps/re2/doc/syntax.html +0 -477
- package/deps/re2/doc/syntax.txt +0 -463
- package/deps/re2/lib/git/commit-msg.hook +0 -104
- package/deps/re2/libre2.symbols +0 -16
- package/deps/re2/libre2.symbols.darwin +0 -12
- package/deps/re2/python/BUILD.bazel +0 -80
- package/deps/re2/python/_re2.cc +0 -352
- package/deps/re2/python/re2.py +0 -583
- package/deps/re2/python/re2_test.py +0 -495
- package/deps/re2/python/setup.py +0 -159
- package/deps/re2/python/toolchains/generate.py +0 -100
- package/deps/re2/re2/bitmap256.cc +0 -43
- package/deps/re2/re2/bitmap256.h +0 -88
- package/deps/re2/re2/bitstate.cc +0 -389
- package/deps/re2/re2/compile.cc +0 -1265
- package/deps/re2/re2/dfa.cc +0 -2135
- package/deps/re2/re2/filtered_re2.cc +0 -138
- package/deps/re2/re2/filtered_re2.h +0 -115
- package/deps/re2/re2/fuzzing/re2_fuzzer.cc +0 -284
- package/deps/re2/re2/make_perl_groups.pl +0 -116
- package/deps/re2/re2/make_unicode_casefold.py +0 -151
- package/deps/re2/re2/make_unicode_groups.py +0 -117
- package/deps/re2/re2/mimics_pcre.cc +0 -196
- package/deps/re2/re2/nfa.cc +0 -714
- package/deps/re2/re2/onepass.cc +0 -623
- package/deps/re2/re2/parse.cc +0 -2529
- package/deps/re2/re2/perl_groups.cc +0 -119
- package/deps/re2/re2/pod_array.h +0 -55
- package/deps/re2/re2/prefilter.cc +0 -711
- package/deps/re2/re2/prefilter.h +0 -168
- package/deps/re2/re2/prefilter_tree.cc +0 -376
- package/deps/re2/re2/prefilter_tree.h +0 -153
- package/deps/re2/re2/prog.cc +0 -1181
- package/deps/re2/re2/prog.h +0 -493
- package/deps/re2/re2/re2.cc +0 -1355
- package/deps/re2/re2/re2.h +0 -1074
- package/deps/re2/re2/regexp.cc +0 -1004
- package/deps/re2/re2/regexp.h +0 -693
- package/deps/re2/re2/set.cc +0 -185
- package/deps/re2/re2/set.h +0 -91
- package/deps/re2/re2/simplify.cc +0 -689
- package/deps/re2/re2/sparse_array.h +0 -394
- package/deps/re2/re2/sparse_set.h +0 -266
- package/deps/re2/re2/stringpiece.h +0 -18
- package/deps/re2/re2/testing/backtrack.cc +0 -274
- package/deps/re2/re2/testing/charclass_test.cc +0 -228
- package/deps/re2/re2/testing/compile_test.cc +0 -431
- package/deps/re2/re2/testing/dfa_test.cc +0 -376
- package/deps/re2/re2/testing/dump.cc +0 -172
- package/deps/re2/re2/testing/exhaustive1_test.cc +0 -40
- package/deps/re2/re2/testing/exhaustive2_test.cc +0 -72
- package/deps/re2/re2/testing/exhaustive3_test.cc +0 -100
- package/deps/re2/re2/testing/exhaustive_test.cc +0 -35
- package/deps/re2/re2/testing/exhaustive_tester.cc +0 -204
- package/deps/re2/re2/testing/exhaustive_tester.h +0 -105
- package/deps/re2/re2/testing/filtered_re2_test.cc +0 -343
- package/deps/re2/re2/testing/mimics_pcre_test.cc +0 -79
- package/deps/re2/re2/testing/null_walker.cc +0 -48
- package/deps/re2/re2/testing/parse_test.cc +0 -586
- package/deps/re2/re2/testing/possible_match_test.cc +0 -251
- package/deps/re2/re2/testing/random_test.cc +0 -102
- package/deps/re2/re2/testing/re2_arg_test.cc +0 -182
- package/deps/re2/re2/testing/re2_test.cc +0 -1699
- package/deps/re2/re2/testing/regexp_benchmark.cc +0 -1605
- package/deps/re2/re2/testing/regexp_generator.cc +0 -284
- package/deps/re2/re2/testing/regexp_generator.h +0 -77
- package/deps/re2/re2/testing/regexp_test.cc +0 -87
- package/deps/re2/re2/testing/required_prefix_test.cc +0 -201
- package/deps/re2/re2/testing/search_test.cc +0 -338
- package/deps/re2/re2/testing/set_test.cc +0 -235
- package/deps/re2/re2/testing/simplify_test.cc +0 -289
- package/deps/re2/re2/testing/string_generator.cc +0 -144
- package/deps/re2/re2/testing/string_generator.h +0 -76
- package/deps/re2/re2/testing/string_generator_test.cc +0 -114
- package/deps/re2/re2/testing/tester.cc +0 -690
- package/deps/re2/re2/testing/tester.h +0 -121
- package/deps/re2/re2/tostring.cc +0 -351
- package/deps/re2/re2/unicode.py +0 -284
- package/deps/re2/re2/unicode_casefold.cc +0 -604
- package/deps/re2/re2/unicode_casefold.h +0 -77
- package/deps/re2/re2/unicode_groups.cc +0 -6517
- package/deps/re2/re2/unicode_groups.h +0 -66
- package/deps/re2/re2/walker-inl.h +0 -249
- package/deps/re2/re2.pc.in +0 -9
- package/deps/re2/re2Config.cmake.in +0 -26
- package/deps/re2/runtests +0 -33
- package/deps/re2/testinstall.cc +0 -27
- package/deps/re2/ucs2.diff +0 -567
- package/deps/re2/util/malloc_counter.h +0 -19
- package/deps/re2/util/pcre.cc +0 -957
- package/deps/re2/util/pcre.h +0 -671
- package/deps/re2/util/rune.cc +0 -260
- package/deps/re2/util/strutil.cc +0 -26
- package/deps/re2/util/strutil.h +0 -16
- package/deps/re2/util/utf.h +0 -44
|
@@ -1,1763 +0,0 @@
|
|
|
1
|
-
// Copyright 2020 The Abseil Authors.
|
|
2
|
-
//
|
|
3
|
-
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
-
// you may not use this file except in compliance with the License.
|
|
5
|
-
// You may obtain a copy of the License at
|
|
6
|
-
//
|
|
7
|
-
// https://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
-
//
|
|
9
|
-
// Unless required by applicable law or agreed to in writing, software
|
|
10
|
-
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
-
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
-
// See the License for the specific language governing permissions and
|
|
13
|
-
// limitations under the License.
|
|
14
|
-
//
|
|
15
|
-
// -----------------------------------------------------------------------------
|
|
16
|
-
// File: cord.h
|
|
17
|
-
// -----------------------------------------------------------------------------
|
|
18
|
-
//
|
|
19
|
-
// This file defines the `absl::Cord` data structure and operations on that data
|
|
20
|
-
// structure. A Cord is a string-like sequence of characters optimized for
|
|
21
|
-
// specific use cases. Unlike a `std::string`, which stores an array of
|
|
22
|
-
// contiguous characters, Cord data is stored in a structure consisting of
|
|
23
|
-
// separate, reference-counted "chunks."
|
|
24
|
-
//
|
|
25
|
-
// Because a Cord consists of these chunks, data can be added to or removed from
|
|
26
|
-
// a Cord during its lifetime. Chunks may also be shared between Cords. Unlike a
|
|
27
|
-
// `std::string`, a Cord can therefore accommodate data that changes over its
|
|
28
|
-
// lifetime, though it's not quite "mutable"; it can change only in the
|
|
29
|
-
// attachment, detachment, or rearrangement of chunks of its constituent data.
|
|
30
|
-
//
|
|
31
|
-
// A Cord provides some benefit over `std::string` under the following (albeit
|
|
32
|
-
// narrow) circumstances:
|
|
33
|
-
//
|
|
34
|
-
// * Cord data is designed to grow and shrink over a Cord's lifetime. Cord
|
|
35
|
-
// provides efficient insertions and deletions at the start and end of the
|
|
36
|
-
// character sequences, avoiding copies in those cases. Static data should
|
|
37
|
-
// generally be stored as strings.
|
|
38
|
-
// * External memory consisting of string-like data can be directly added to
|
|
39
|
-
// a Cord without requiring copies or allocations.
|
|
40
|
-
// * Cord data may be shared and copied cheaply. Cord provides a copy-on-write
|
|
41
|
-
// implementation and cheap sub-Cord operations. Copying a Cord is an O(1)
|
|
42
|
-
// operation.
|
|
43
|
-
//
|
|
44
|
-
// As a consequence to the above, Cord data is generally large. Small data
|
|
45
|
-
// should generally use strings, as construction of a Cord requires some
|
|
46
|
-
// overhead. Small Cords (<= 15 bytes) are represented inline, but most small
|
|
47
|
-
// Cords are expected to grow over their lifetimes.
|
|
48
|
-
//
|
|
49
|
-
// Note that because a Cord is made up of separate chunked data, random access
|
|
50
|
-
// to character data within a Cord is slower than within a `std::string`.
|
|
51
|
-
//
|
|
52
|
-
// Thread Safety
|
|
53
|
-
//
|
|
54
|
-
// Cord has the same thread-safety properties as many other types like
|
|
55
|
-
// std::string, std::vector<>, int, etc -- it is thread-compatible. In
|
|
56
|
-
// particular, if threads do not call non-const methods, then it is safe to call
|
|
57
|
-
// const methods without synchronization. Copying a Cord produces a new instance
|
|
58
|
-
// that can be used concurrently with the original in arbitrary ways.
|
|
59
|
-
|
|
60
|
-
#ifndef ABSL_STRINGS_CORD_H_
|
|
61
|
-
#define ABSL_STRINGS_CORD_H_
|
|
62
|
-
|
|
63
|
-
#include <algorithm>
|
|
64
|
-
#include <cassert>
|
|
65
|
-
#include <cstddef>
|
|
66
|
-
#include <cstdint>
|
|
67
|
-
#include <cstring>
|
|
68
|
-
#include <iosfwd>
|
|
69
|
-
#include <iterator>
|
|
70
|
-
#include <string>
|
|
71
|
-
#include <type_traits>
|
|
72
|
-
#include <utility>
|
|
73
|
-
|
|
74
|
-
#include "absl/base/attributes.h"
|
|
75
|
-
#include "absl/base/config.h"
|
|
76
|
-
#include "absl/base/internal/endian.h"
|
|
77
|
-
#include "absl/base/macros.h"
|
|
78
|
-
#include "absl/base/nullability.h"
|
|
79
|
-
#include "absl/base/optimization.h"
|
|
80
|
-
#include "absl/crc/internal/crc_cord_state.h"
|
|
81
|
-
#include "absl/functional/function_ref.h"
|
|
82
|
-
#include "absl/hash/internal/weakly_mixed_integer.h"
|
|
83
|
-
#include "absl/meta/type_traits.h"
|
|
84
|
-
#include "absl/strings/cord_analysis.h"
|
|
85
|
-
#include "absl/strings/cord_buffer.h"
|
|
86
|
-
#include "absl/strings/internal/cord_data_edge.h"
|
|
87
|
-
#include "absl/strings/internal/cord_internal.h"
|
|
88
|
-
#include "absl/strings/internal/cord_rep_btree.h"
|
|
89
|
-
#include "absl/strings/internal/cord_rep_btree_reader.h"
|
|
90
|
-
#include "absl/strings/internal/cord_rep_crc.h"
|
|
91
|
-
#include "absl/strings/internal/cord_rep_flat.h"
|
|
92
|
-
#include "absl/strings/internal/cordz_info.h"
|
|
93
|
-
#include "absl/strings/internal/cordz_update_scope.h"
|
|
94
|
-
#include "absl/strings/internal/cordz_update_tracker.h"
|
|
95
|
-
#include "absl/strings/internal/string_constant.h"
|
|
96
|
-
#include "absl/strings/string_view.h"
|
|
97
|
-
#include "absl/types/compare.h"
|
|
98
|
-
#include "absl/types/optional.h"
|
|
99
|
-
|
|
100
|
-
namespace absl {
|
|
101
|
-
ABSL_NAMESPACE_BEGIN
|
|
102
|
-
class Cord;
|
|
103
|
-
class CordTestPeer;
|
|
104
|
-
template <typename Releaser>
|
|
105
|
-
Cord MakeCordFromExternal(absl::string_view, Releaser&&);
|
|
106
|
-
void CopyCordToString(const Cord& src, std::string* absl_nonnull dst);
|
|
107
|
-
void AppendCordToString(const Cord& src, std::string* absl_nonnull dst);
|
|
108
|
-
|
|
109
|
-
// Cord memory accounting modes
|
|
110
|
-
enum class CordMemoryAccounting {
|
|
111
|
-
// Counts the *approximate* number of bytes held in full or in part by this
|
|
112
|
-
// Cord (which may not remain the same between invocations). Cords that share
|
|
113
|
-
// memory could each be "charged" independently for the same shared memory.
|
|
114
|
-
// See also comment on `kTotalMorePrecise` on internally shared memory.
|
|
115
|
-
kTotal,
|
|
116
|
-
|
|
117
|
-
// Counts the *approximate* number of bytes held in full or in part by this
|
|
118
|
-
// Cord for the distinct memory held by this cord. This option is similar
|
|
119
|
-
// to `kTotal`, except that if the cord has multiple references to the same
|
|
120
|
-
// memory, that memory is only counted once.
|
|
121
|
-
//
|
|
122
|
-
// For example:
|
|
123
|
-
// absl::Cord cord;
|
|
124
|
-
// cord.Append(some_other_cord);
|
|
125
|
-
// cord.Append(some_other_cord);
|
|
126
|
-
// // Counts `some_other_cord` twice:
|
|
127
|
-
// cord.EstimatedMemoryUsage(kTotal);
|
|
128
|
-
// // Counts `some_other_cord` once:
|
|
129
|
-
// cord.EstimatedMemoryUsage(kTotalMorePrecise);
|
|
130
|
-
//
|
|
131
|
-
// The `kTotalMorePrecise` number is more expensive to compute as it requires
|
|
132
|
-
// deduplicating all memory references. Applications should prefer to use
|
|
133
|
-
// `kFairShare` or `kTotal` unless they really need a more precise estimate
|
|
134
|
-
// on "how much memory is potentially held / kept alive by this cord?"
|
|
135
|
-
kTotalMorePrecise,
|
|
136
|
-
|
|
137
|
-
// Counts the *approximate* number of bytes held in full or in part by this
|
|
138
|
-
// Cord weighted by the sharing ratio of that data. For example, if some data
|
|
139
|
-
// edge is shared by 4 different Cords, then each cord is attributed 1/4th of
|
|
140
|
-
// the total memory usage as a 'fair share' of the total memory usage.
|
|
141
|
-
kFairShare,
|
|
142
|
-
};
|
|
143
|
-
|
|
144
|
-
// Cord
|
|
145
|
-
//
|
|
146
|
-
// A Cord is a sequence of characters, designed to be more efficient than a
|
|
147
|
-
// `std::string` in certain circumstances: namely, large string data that needs
|
|
148
|
-
// to change over its lifetime or shared, especially when such data is shared
|
|
149
|
-
// across API boundaries.
|
|
150
|
-
//
|
|
151
|
-
// A Cord stores its character data in a structure that allows efficient prepend
|
|
152
|
-
// and append operations. This makes a Cord useful for large string data sent
|
|
153
|
-
// over in a wire format that may need to be prepended or appended at some point
|
|
154
|
-
// during the data exchange (e.g. HTTP, protocol buffers). For example, a
|
|
155
|
-
// Cord is useful for storing an HTTP request, and prepending an HTTP header to
|
|
156
|
-
// such a request.
|
|
157
|
-
//
|
|
158
|
-
// Cords should not be used for storing general string data, however. They
|
|
159
|
-
// require overhead to construct and are slower than strings for random access.
|
|
160
|
-
//
|
|
161
|
-
// The Cord API provides the following common API operations:
|
|
162
|
-
//
|
|
163
|
-
// * Create or assign Cords out of existing string data, memory, or other Cords
|
|
164
|
-
// * Append and prepend data to an existing Cord
|
|
165
|
-
// * Create new Sub-Cords from existing Cord data
|
|
166
|
-
// * Swap Cord data and compare Cord equality
|
|
167
|
-
// * Write out Cord data by constructing a `std::string`
|
|
168
|
-
//
|
|
169
|
-
// Additionally, the API provides iterator utilities to iterate through Cord
|
|
170
|
-
// data via chunks or character bytes.
|
|
171
|
-
//
|
|
172
|
-
class Cord {
|
|
173
|
-
private:
|
|
174
|
-
template <typename T>
|
|
175
|
-
using EnableIfString =
|
|
176
|
-
absl::enable_if_t<std::is_same<T, std::string>::value, int>;
|
|
177
|
-
|
|
178
|
-
public:
|
|
179
|
-
// Cord::Cord() Constructors.
|
|
180
|
-
|
|
181
|
-
// Creates an empty Cord.
|
|
182
|
-
constexpr Cord() noexcept;
|
|
183
|
-
|
|
184
|
-
// Creates a Cord from an existing Cord. Cord is copyable and efficiently
|
|
185
|
-
// movable. The moved-from state is valid but unspecified.
|
|
186
|
-
Cord(const Cord& src);
|
|
187
|
-
Cord(Cord&& src) noexcept;
|
|
188
|
-
Cord& operator=(const Cord& x);
|
|
189
|
-
Cord& operator=(Cord&& x) noexcept;
|
|
190
|
-
|
|
191
|
-
// Creates a Cord from a `src` string. This constructor is marked explicit to
|
|
192
|
-
// prevent implicit Cord constructions from arguments convertible to an
|
|
193
|
-
// `absl::string_view`.
|
|
194
|
-
explicit Cord(absl::string_view src);
|
|
195
|
-
Cord& operator=(absl::string_view src);
|
|
196
|
-
|
|
197
|
-
// Creates a Cord from a `std::string&&` rvalue. These constructors are
|
|
198
|
-
// templated to avoid ambiguities for types that are convertible to both
|
|
199
|
-
// `absl::string_view` and `std::string`, such as `const char*`.
|
|
200
|
-
template <typename T, EnableIfString<T> = 0>
|
|
201
|
-
explicit Cord(T&& src);
|
|
202
|
-
template <typename T, EnableIfString<T> = 0>
|
|
203
|
-
Cord& operator=(T&& src);
|
|
204
|
-
|
|
205
|
-
// Cord::~Cord()
|
|
206
|
-
//
|
|
207
|
-
// Destructs the Cord.
|
|
208
|
-
~Cord() {
|
|
209
|
-
if (contents_.is_tree()) DestroyCordSlow();
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
// MakeCordFromExternal()
|
|
213
|
-
//
|
|
214
|
-
// Creates a Cord that takes ownership of external string memory. The
|
|
215
|
-
// contents of `data` are not copied to the Cord; instead, the external
|
|
216
|
-
// memory is added to the Cord and reference-counted. This data may not be
|
|
217
|
-
// changed for the life of the Cord, though it may be prepended or appended
|
|
218
|
-
// to.
|
|
219
|
-
//
|
|
220
|
-
// `MakeCordFromExternal()` takes a callable "releaser" that is invoked when
|
|
221
|
-
// the reference count for `data` reaches zero. As noted above, this data must
|
|
222
|
-
// remain live until the releaser is invoked. The callable releaser also must:
|
|
223
|
-
//
|
|
224
|
-
// * be move constructible
|
|
225
|
-
// * support `void operator()(absl::string_view) const` or `void operator()`
|
|
226
|
-
//
|
|
227
|
-
// Example:
|
|
228
|
-
//
|
|
229
|
-
// Cord MakeCord(BlockPool* pool) {
|
|
230
|
-
// Block* block = pool->NewBlock();
|
|
231
|
-
// FillBlock(block);
|
|
232
|
-
// return absl::MakeCordFromExternal(
|
|
233
|
-
// block->ToStringView(),
|
|
234
|
-
// [pool, block](absl::string_view v) {
|
|
235
|
-
// pool->FreeBlock(block, v);
|
|
236
|
-
// });
|
|
237
|
-
// }
|
|
238
|
-
//
|
|
239
|
-
// WARNING: Because a Cord can be reference-counted, it's likely a bug if your
|
|
240
|
-
// releaser doesn't do anything. For example, consider the following:
|
|
241
|
-
//
|
|
242
|
-
// void Foo(const char* buffer, int len) {
|
|
243
|
-
// auto c = absl::MakeCordFromExternal(absl::string_view(buffer, len),
|
|
244
|
-
// [](absl::string_view) {});
|
|
245
|
-
//
|
|
246
|
-
// // BUG: If Bar() copies its cord for any reason, including keeping a
|
|
247
|
-
// // substring of it, the lifetime of buffer might be extended beyond
|
|
248
|
-
// // when Foo() returns.
|
|
249
|
-
// Bar(c);
|
|
250
|
-
// }
|
|
251
|
-
template <typename Releaser>
|
|
252
|
-
friend Cord MakeCordFromExternal(absl::string_view data, Releaser&& releaser);
|
|
253
|
-
|
|
254
|
-
// Cord::Clear()
|
|
255
|
-
//
|
|
256
|
-
// Releases the Cord data. Any nodes that share data with other Cords, if
|
|
257
|
-
// applicable, will have their reference counts reduced by 1.
|
|
258
|
-
ABSL_ATTRIBUTE_REINITIALIZES void Clear();
|
|
259
|
-
|
|
260
|
-
// Cord::Append()
|
|
261
|
-
//
|
|
262
|
-
// Appends data to the Cord, which may come from another Cord or other string
|
|
263
|
-
// data.
|
|
264
|
-
void Append(const Cord& src);
|
|
265
|
-
void Append(Cord&& src);
|
|
266
|
-
void Append(absl::string_view src);
|
|
267
|
-
template <typename T, EnableIfString<T> = 0>
|
|
268
|
-
void Append(T&& src);
|
|
269
|
-
|
|
270
|
-
// Appends `buffer` to this cord, unless `buffer` has a zero length in which
|
|
271
|
-
// case this method has no effect on this cord instance.
|
|
272
|
-
// This method is guaranteed to consume `buffer`.
|
|
273
|
-
void Append(CordBuffer buffer);
|
|
274
|
-
|
|
275
|
-
// Returns a CordBuffer, re-using potential existing capacity in this cord.
|
|
276
|
-
//
|
|
277
|
-
// Cord instances may have additional unused capacity in the last (or first)
|
|
278
|
-
// nodes of the underlying tree to facilitate amortized growth. This method
|
|
279
|
-
// allows applications to explicitly use this spare capacity if available,
|
|
280
|
-
// or create a new CordBuffer instance otherwise.
|
|
281
|
-
// If this cord has a final non-shared node with at least `min_capacity`
|
|
282
|
-
// available, then this method will return that buffer including its data
|
|
283
|
-
// contents. I.e.; the returned buffer will have a non-zero length, and
|
|
284
|
-
// a capacity of at least `buffer.length + min_capacity`. Otherwise, this
|
|
285
|
-
// method will return `CordBuffer::CreateWithDefaultLimit(capacity)`.
|
|
286
|
-
//
|
|
287
|
-
// Below an example of using GetAppendBuffer. Notice that in this example we
|
|
288
|
-
// use `GetAppendBuffer()` only on the first iteration. As we know nothing
|
|
289
|
-
// about any initial extra capacity in `cord`, we may be able to use the extra
|
|
290
|
-
// capacity. But as we add new buffers with fully utilized contents after that
|
|
291
|
-
// we avoid calling `GetAppendBuffer()` on subsequent iterations: while this
|
|
292
|
-
// works fine, it results in an unnecessary inspection of cord contents:
|
|
293
|
-
//
|
|
294
|
-
// void AppendRandomDataToCord(absl::Cord &cord, size_t n) {
|
|
295
|
-
// bool first = true;
|
|
296
|
-
// while (n > 0) {
|
|
297
|
-
// CordBuffer buffer = first ? cord.GetAppendBuffer(n)
|
|
298
|
-
// : CordBuffer::CreateWithDefaultLimit(n);
|
|
299
|
-
// absl::Span<char> data = buffer.available_up_to(n);
|
|
300
|
-
// FillRandomValues(data.data(), data.size());
|
|
301
|
-
// buffer.IncreaseLengthBy(data.size());
|
|
302
|
-
// cord.Append(std::move(buffer));
|
|
303
|
-
// n -= data.size();
|
|
304
|
-
// first = false;
|
|
305
|
-
// }
|
|
306
|
-
// }
|
|
307
|
-
CordBuffer GetAppendBuffer(size_t capacity, size_t min_capacity = 16);
|
|
308
|
-
|
|
309
|
-
// Returns a CordBuffer, re-using potential existing capacity in this cord.
|
|
310
|
-
//
|
|
311
|
-
// This function is identical to `GetAppendBuffer`, except that in the case
|
|
312
|
-
// where a new `CordBuffer` is allocated, it is allocated using the provided
|
|
313
|
-
// custom limit instead of the default limit. `GetAppendBuffer` will default
|
|
314
|
-
// to `CordBuffer::CreateWithDefaultLimit(capacity)` whereas this method
|
|
315
|
-
// will default to `CordBuffer::CreateWithCustomLimit(block_size, capacity)`.
|
|
316
|
-
// This method is equivalent to `GetAppendBuffer` if `block_size` is zero.
|
|
317
|
-
// See the documentation for `CreateWithCustomLimit` for more details on the
|
|
318
|
-
// restrictions and legal values for `block_size`.
|
|
319
|
-
CordBuffer GetCustomAppendBuffer(size_t block_size, size_t capacity,
|
|
320
|
-
size_t min_capacity = 16);
|
|
321
|
-
|
|
322
|
-
// Cord::Prepend()
|
|
323
|
-
//
|
|
324
|
-
// Prepends data to the Cord, which may come from another Cord or other string
|
|
325
|
-
// data.
|
|
326
|
-
void Prepend(const Cord& src);
|
|
327
|
-
void Prepend(absl::string_view src);
|
|
328
|
-
template <typename T, EnableIfString<T> = 0>
|
|
329
|
-
void Prepend(T&& src);
|
|
330
|
-
|
|
331
|
-
// Prepends `buffer` to this cord, unless `buffer` has a zero length in which
|
|
332
|
-
// case this method has no effect on this cord instance.
|
|
333
|
-
// This method is guaranteed to consume `buffer`.
|
|
334
|
-
void Prepend(CordBuffer buffer);
|
|
335
|
-
|
|
336
|
-
// Cord::RemovePrefix()
|
|
337
|
-
//
|
|
338
|
-
// Removes the first `n` bytes of a Cord.
|
|
339
|
-
void RemovePrefix(size_t n);
|
|
340
|
-
void RemoveSuffix(size_t n);
|
|
341
|
-
|
|
342
|
-
// Cord::Subcord()
|
|
343
|
-
//
|
|
344
|
-
// Returns a new Cord representing the subrange [pos, pos + new_size) of
|
|
345
|
-
// *this. If pos >= size(), the result is empty(). If
|
|
346
|
-
// (pos + new_size) >= size(), the result is the subrange [pos, size()).
|
|
347
|
-
Cord Subcord(size_t pos, size_t new_size) const;
|
|
348
|
-
|
|
349
|
-
// Cord::swap()
|
|
350
|
-
//
|
|
351
|
-
// Swaps the contents of the Cord with `other`.
|
|
352
|
-
void swap(Cord& other) noexcept;
|
|
353
|
-
|
|
354
|
-
// swap()
|
|
355
|
-
//
|
|
356
|
-
// Swaps the contents of two Cords.
|
|
357
|
-
friend void swap(Cord& x, Cord& y) noexcept { x.swap(y); }
|
|
358
|
-
|
|
359
|
-
// Cord::size()
|
|
360
|
-
//
|
|
361
|
-
// Returns the size of the Cord.
|
|
362
|
-
size_t size() const;
|
|
363
|
-
|
|
364
|
-
// Cord::empty()
|
|
365
|
-
//
|
|
366
|
-
// Determines whether the given Cord is empty, returning `true` if so.
|
|
367
|
-
bool empty() const;
|
|
368
|
-
|
|
369
|
-
// Cord::EstimatedMemoryUsage()
|
|
370
|
-
//
|
|
371
|
-
// Returns the *approximate* number of bytes held by this cord.
|
|
372
|
-
// See CordMemoryAccounting for more information on the accounting method.
|
|
373
|
-
size_t EstimatedMemoryUsage(CordMemoryAccounting accounting_method =
|
|
374
|
-
CordMemoryAccounting::kTotal) const;
|
|
375
|
-
|
|
376
|
-
// Cord::Compare()
|
|
377
|
-
//
|
|
378
|
-
// Compares 'this' Cord with rhs. This function and its relatives treat Cords
|
|
379
|
-
// as sequences of unsigned bytes. The comparison is a straightforward
|
|
380
|
-
// lexicographic comparison. `Cord::Compare()` returns values as follows:
|
|
381
|
-
//
|
|
382
|
-
// -1 'this' Cord is smaller
|
|
383
|
-
// 0 two Cords are equal
|
|
384
|
-
// 1 'this' Cord is larger
|
|
385
|
-
int Compare(absl::string_view rhs) const;
|
|
386
|
-
int Compare(const Cord& rhs) const;
|
|
387
|
-
|
|
388
|
-
// Cord::StartsWith()
|
|
389
|
-
//
|
|
390
|
-
// Determines whether the Cord starts with the passed string data `rhs`.
|
|
391
|
-
bool StartsWith(const Cord& rhs) const;
|
|
392
|
-
bool StartsWith(absl::string_view rhs) const;
|
|
393
|
-
|
|
394
|
-
// Cord::EndsWith()
|
|
395
|
-
//
|
|
396
|
-
// Determines whether the Cord ends with the passed string data `rhs`.
|
|
397
|
-
bool EndsWith(absl::string_view rhs) const;
|
|
398
|
-
bool EndsWith(const Cord& rhs) const;
|
|
399
|
-
|
|
400
|
-
// Cord::Contains()
|
|
401
|
-
//
|
|
402
|
-
// Determines whether the Cord contains the passed string data `rhs`.
|
|
403
|
-
bool Contains(absl::string_view rhs) const;
|
|
404
|
-
bool Contains(const Cord& rhs) const;
|
|
405
|
-
|
|
406
|
-
// Cord::operator std::string()
|
|
407
|
-
//
|
|
408
|
-
// Converts a Cord into a `std::string()`. This operator is marked explicit to
|
|
409
|
-
// prevent unintended Cord usage in functions that take a string.
|
|
410
|
-
explicit operator std::string() const;
|
|
411
|
-
|
|
412
|
-
// CopyCordToString()
|
|
413
|
-
//
|
|
414
|
-
// Copies the contents of a `src` Cord into a `*dst` string.
|
|
415
|
-
//
|
|
416
|
-
// This function optimizes the case of reusing the destination string since it
|
|
417
|
-
// can reuse previously allocated capacity. However, this function does not
|
|
418
|
-
// guarantee that pointers previously returned by `dst->data()` remain valid
|
|
419
|
-
// even if `*dst` had enough capacity to hold `src`. If `*dst` is a new
|
|
420
|
-
// object, prefer to simply use the conversion operator to `std::string`.
|
|
421
|
-
friend void CopyCordToString(const Cord& src, std::string* absl_nonnull dst);
|
|
422
|
-
|
|
423
|
-
// AppendCordToString()
|
|
424
|
-
//
|
|
425
|
-
// Appends the contents of a `src` Cord to a `*dst` string.
|
|
426
|
-
//
|
|
427
|
-
// This function optimizes the case of appending to a non-empty destination
|
|
428
|
-
// string. If `*dst` already has capacity to store the contents of the cord,
|
|
429
|
-
// this function does not invalidate pointers previously returned by
|
|
430
|
-
// `dst->data()`. If `*dst` is a new object, prefer to simply use the
|
|
431
|
-
// conversion operator to `std::string`.
|
|
432
|
-
friend void AppendCordToString(const Cord& src,
|
|
433
|
-
std::string* absl_nonnull dst);
|
|
434
|
-
|
|
435
|
-
class CharIterator;
|
|
436
|
-
|
|
437
|
-
//----------------------------------------------------------------------------
|
|
438
|
-
// Cord::ChunkIterator
|
|
439
|
-
//----------------------------------------------------------------------------
|
|
440
|
-
//
|
|
441
|
-
// A `Cord::ChunkIterator` allows iteration over the constituent chunks of its
|
|
442
|
-
// Cord. Such iteration allows you to perform non-const operations on the data
|
|
443
|
-
// of a Cord without modifying it.
|
|
444
|
-
//
|
|
445
|
-
// Generally, you do not instantiate a `Cord::ChunkIterator` directly;
|
|
446
|
-
// instead, you create one implicitly through use of the `Cord::Chunks()`
|
|
447
|
-
// member function.
|
|
448
|
-
//
|
|
449
|
-
// The `Cord::ChunkIterator` has the following properties:
|
|
450
|
-
//
|
|
451
|
-
// * The iterator is invalidated after any non-const operation on the
|
|
452
|
-
// Cord object over which it iterates.
|
|
453
|
-
// * The `string_view` returned by dereferencing a valid, non-`end()`
|
|
454
|
-
// iterator is guaranteed to be non-empty.
|
|
455
|
-
// * Two `ChunkIterator` objects can be compared equal if and only if they
|
|
456
|
-
// remain valid and iterate over the same Cord.
|
|
457
|
-
// * The iterator in this case is a proxy iterator; the `string_view`
|
|
458
|
-
// returned by the iterator does not live inside the Cord, and its
|
|
459
|
-
// lifetime is limited to the lifetime of the iterator itself. To help
|
|
460
|
-
// prevent lifetime issues, `ChunkIterator::reference` is not a true
|
|
461
|
-
// reference type and is equivalent to `value_type`.
|
|
462
|
-
// * The iterator keeps state that can grow for Cords that contain many
|
|
463
|
-
// nodes and are imbalanced due to sharing. Prefer to pass this type by
|
|
464
|
-
// const reference instead of by value.
|
|
465
|
-
class ChunkIterator {
|
|
466
|
-
public:
|
|
467
|
-
using iterator_category = std::input_iterator_tag;
|
|
468
|
-
using value_type = absl::string_view;
|
|
469
|
-
using difference_type = ptrdiff_t;
|
|
470
|
-
using pointer = const value_type* absl_nonnull;
|
|
471
|
-
using reference = value_type;
|
|
472
|
-
|
|
473
|
-
ChunkIterator() = default;
|
|
474
|
-
|
|
475
|
-
ChunkIterator& operator++();
|
|
476
|
-
ChunkIterator operator++(int);
|
|
477
|
-
bool operator==(const ChunkIterator& other) const;
|
|
478
|
-
bool operator!=(const ChunkIterator& other) const;
|
|
479
|
-
reference operator*() const;
|
|
480
|
-
pointer operator->() const;
|
|
481
|
-
|
|
482
|
-
friend class Cord;
|
|
483
|
-
friend class CharIterator;
|
|
484
|
-
|
|
485
|
-
private:
|
|
486
|
-
using CordRep = absl::cord_internal::CordRep;
|
|
487
|
-
using CordRepBtree = absl::cord_internal::CordRepBtree;
|
|
488
|
-
using CordRepBtreeReader = absl::cord_internal::CordRepBtreeReader;
|
|
489
|
-
|
|
490
|
-
// Constructs a `begin()` iterator from `tree`.
|
|
491
|
-
explicit ChunkIterator(cord_internal::CordRep* absl_nonnull tree);
|
|
492
|
-
|
|
493
|
-
// Constructs a `begin()` iterator from `cord`.
|
|
494
|
-
explicit ChunkIterator(const Cord* absl_nonnull cord);
|
|
495
|
-
|
|
496
|
-
// Initializes this instance from a tree. Invoked by constructors.
|
|
497
|
-
void InitTree(cord_internal::CordRep* absl_nonnull tree);
|
|
498
|
-
|
|
499
|
-
// Removes `n` bytes from `current_chunk_`. Expects `n` to be smaller than
|
|
500
|
-
// `current_chunk_.size()`.
|
|
501
|
-
void RemoveChunkPrefix(size_t n);
|
|
502
|
-
Cord AdvanceAndReadBytes(size_t n);
|
|
503
|
-
void AdvanceBytes(size_t n);
|
|
504
|
-
|
|
505
|
-
// Btree specific operator++
|
|
506
|
-
ChunkIterator& AdvanceBtree();
|
|
507
|
-
void AdvanceBytesBtree(size_t n);
|
|
508
|
-
|
|
509
|
-
// A view into bytes of the current `CordRep`. It may only be a view to a
|
|
510
|
-
// suffix of bytes if this is being used by `CharIterator`.
|
|
511
|
-
absl::string_view current_chunk_;
|
|
512
|
-
// The current leaf, or `nullptr` if the iterator points to short data.
|
|
513
|
-
// If the current chunk is a substring node, current_leaf_ points to the
|
|
514
|
-
// underlying flat or external node.
|
|
515
|
-
absl::cord_internal::CordRep* absl_nullable current_leaf_ = nullptr;
|
|
516
|
-
// The number of bytes left in the `Cord` over which we are iterating.
|
|
517
|
-
size_t bytes_remaining_ = 0;
|
|
518
|
-
|
|
519
|
-
// Cord reader for cord btrees. Empty if not traversing a btree.
|
|
520
|
-
CordRepBtreeReader btree_reader_;
|
|
521
|
-
};
|
|
522
|
-
|
|
523
|
-
// Cord::chunk_begin()
|
|
524
|
-
//
|
|
525
|
-
// Returns an iterator to the first chunk of the `Cord`.
|
|
526
|
-
//
|
|
527
|
-
// Generally, prefer using `Cord::Chunks()` within a range-based for loop for
|
|
528
|
-
// iterating over the chunks of a Cord. This method may be useful for getting
|
|
529
|
-
// a `ChunkIterator` where range-based for-loops are not useful.
|
|
530
|
-
//
|
|
531
|
-
// Example:
|
|
532
|
-
//
|
|
533
|
-
// absl::Cord::ChunkIterator FindAsChunk(const absl::Cord& c,
|
|
534
|
-
// absl::string_view s) {
|
|
535
|
-
// return std::find(c.chunk_begin(), c.chunk_end(), s);
|
|
536
|
-
// }
|
|
537
|
-
ChunkIterator chunk_begin() const ABSL_ATTRIBUTE_LIFETIME_BOUND;
|
|
538
|
-
|
|
539
|
-
// Cord::chunk_end()
|
|
540
|
-
//
|
|
541
|
-
// Returns an iterator one increment past the last chunk of the `Cord`.
|
|
542
|
-
//
|
|
543
|
-
// Generally, prefer using `Cord::Chunks()` within a range-based for loop for
|
|
544
|
-
// iterating over the chunks of a Cord. This method may be useful for getting
|
|
545
|
-
// a `ChunkIterator` where range-based for-loops may not be available.
|
|
546
|
-
ChunkIterator chunk_end() const ABSL_ATTRIBUTE_LIFETIME_BOUND;
|
|
547
|
-
|
|
548
|
-
//----------------------------------------------------------------------------
|
|
549
|
-
// Cord::ChunkRange
|
|
550
|
-
//----------------------------------------------------------------------------
|
|
551
|
-
//
|
|
552
|
-
// `ChunkRange` is a helper class for iterating over the chunks of the `Cord`,
|
|
553
|
-
// producing an iterator which can be used within a range-based for loop.
|
|
554
|
-
// Construction of a `ChunkRange` will return an iterator pointing to the
|
|
555
|
-
// first chunk of the Cord. Generally, do not construct a `ChunkRange`
|
|
556
|
-
// directly; instead, prefer to use the `Cord::Chunks()` method.
|
|
557
|
-
//
|
|
558
|
-
// Implementation note: `ChunkRange` is simply a convenience wrapper over
|
|
559
|
-
// `Cord::chunk_begin()` and `Cord::chunk_end()`.
|
|
560
|
-
class ChunkRange {
|
|
561
|
-
public:
|
|
562
|
-
// Fulfill minimum c++ container requirements [container.requirements]
|
|
563
|
-
// These (partial) container type definitions allow ChunkRange to be used
|
|
564
|
-
// in various utilities expecting a subset of [container.requirements].
|
|
565
|
-
// For example, the below enables using `::testing::ElementsAre(...)`
|
|
566
|
-
using value_type = absl::string_view;
|
|
567
|
-
using reference = value_type&;
|
|
568
|
-
using const_reference = const value_type&;
|
|
569
|
-
using iterator = ChunkIterator;
|
|
570
|
-
using const_iterator = ChunkIterator;
|
|
571
|
-
|
|
572
|
-
explicit ChunkRange(const Cord* absl_nonnull cord) : cord_(cord) {}
|
|
573
|
-
|
|
574
|
-
ChunkIterator begin() const;
|
|
575
|
-
ChunkIterator end() const;
|
|
576
|
-
|
|
577
|
-
private:
|
|
578
|
-
const Cord* absl_nonnull cord_;
|
|
579
|
-
};
|
|
580
|
-
|
|
581
|
-
// Cord::Chunks()
|
|
582
|
-
//
|
|
583
|
-
// Returns a `Cord::ChunkRange` for iterating over the chunks of a `Cord` with
|
|
584
|
-
// a range-based for-loop. For most iteration tasks on a Cord, use
|
|
585
|
-
// `Cord::Chunks()` to retrieve this iterator.
|
|
586
|
-
//
|
|
587
|
-
// Example:
|
|
588
|
-
//
|
|
589
|
-
// void ProcessChunks(const Cord& cord) {
|
|
590
|
-
// for (absl::string_view chunk : cord.Chunks()) { ... }
|
|
591
|
-
// }
|
|
592
|
-
//
|
|
593
|
-
// Note that the ordinary caveats of temporary lifetime extension apply:
|
|
594
|
-
//
|
|
595
|
-
// void Process() {
|
|
596
|
-
// for (absl::string_view chunk : CordFactory().Chunks()) {
|
|
597
|
-
// // The temporary Cord returned by CordFactory has been destroyed!
|
|
598
|
-
// }
|
|
599
|
-
// }
|
|
600
|
-
ChunkRange Chunks() const ABSL_ATTRIBUTE_LIFETIME_BOUND;
|
|
601
|
-
|
|
602
|
-
//----------------------------------------------------------------------------
|
|
603
|
-
// Cord::CharIterator
|
|
604
|
-
//----------------------------------------------------------------------------
|
|
605
|
-
//
|
|
606
|
-
// A `Cord::CharIterator` allows iteration over the constituent characters of
|
|
607
|
-
// a `Cord`.
|
|
608
|
-
//
|
|
609
|
-
// Generally, you do not instantiate a `Cord::CharIterator` directly; instead,
|
|
610
|
-
// you create one implicitly through use of the `Cord::Chars()` member
|
|
611
|
-
// function.
|
|
612
|
-
//
|
|
613
|
-
// A `Cord::CharIterator` has the following properties:
|
|
614
|
-
//
|
|
615
|
-
// * The iterator is invalidated after any non-const operation on the
|
|
616
|
-
// Cord object over which it iterates.
|
|
617
|
-
// * Two `CharIterator` objects can be compared equal if and only if they
|
|
618
|
-
// remain valid and iterate over the same Cord.
|
|
619
|
-
// * The iterator keeps state that can grow for Cords that contain many
|
|
620
|
-
// nodes and are imbalanced due to sharing. Prefer to pass this type by
|
|
621
|
-
// const reference instead of by value.
|
|
622
|
-
// * This type cannot act as a forward iterator because a `Cord` can reuse
|
|
623
|
-
// sections of memory. This fact violates the requirement for forward
|
|
624
|
-
// iterators to compare equal if dereferencing them returns the same
|
|
625
|
-
// object.
|
|
626
|
-
class CharIterator {
|
|
627
|
-
public:
|
|
628
|
-
using iterator_category = std::input_iterator_tag;
|
|
629
|
-
using value_type = char;
|
|
630
|
-
using difference_type = ptrdiff_t;
|
|
631
|
-
using pointer = const char* absl_nonnull;
|
|
632
|
-
using reference = const char&;
|
|
633
|
-
|
|
634
|
-
CharIterator() = default;
|
|
635
|
-
|
|
636
|
-
CharIterator& operator++();
|
|
637
|
-
CharIterator operator++(int);
|
|
638
|
-
bool operator==(const CharIterator& other) const;
|
|
639
|
-
bool operator!=(const CharIterator& other) const;
|
|
640
|
-
reference operator*() const;
|
|
641
|
-
|
|
642
|
-
friend Cord;
|
|
643
|
-
|
|
644
|
-
private:
|
|
645
|
-
explicit CharIterator(const Cord* absl_nonnull cord)
|
|
646
|
-
: chunk_iterator_(cord) {}
|
|
647
|
-
|
|
648
|
-
ChunkIterator chunk_iterator_;
|
|
649
|
-
};
|
|
650
|
-
|
|
651
|
-
// Cord::AdvanceAndRead()
|
|
652
|
-
//
|
|
653
|
-
// Advances the `Cord::CharIterator` by `n_bytes` and returns the bytes
|
|
654
|
-
// advanced as a separate `Cord`. `n_bytes` must be less than or equal to the
|
|
655
|
-
// number of bytes within the Cord; otherwise, behavior is undefined. It is
|
|
656
|
-
// valid to pass `char_end()` and `0`.
|
|
657
|
-
static Cord AdvanceAndRead(CharIterator* absl_nonnull it, size_t n_bytes);
|
|
658
|
-
|
|
659
|
-
// Cord::Advance()
|
|
660
|
-
//
|
|
661
|
-
// Advances the `Cord::CharIterator` by `n_bytes`. `n_bytes` must be less than
|
|
662
|
-
// or equal to the number of bytes remaining within the Cord; otherwise,
|
|
663
|
-
// behavior is undefined. It is valid to pass `char_end()` and `0`.
|
|
664
|
-
static void Advance(CharIterator* absl_nonnull it, size_t n_bytes);
|
|
665
|
-
|
|
666
|
-
// Cord::ChunkRemaining()
|
|
667
|
-
//
|
|
668
|
-
// Returns the longest contiguous view starting at the iterator's position.
|
|
669
|
-
//
|
|
670
|
-
// `it` must be dereferenceable.
|
|
671
|
-
static absl::string_view ChunkRemaining(const CharIterator& it);
|
|
672
|
-
|
|
673
|
-
// Cord::Distance()
|
|
674
|
-
//
|
|
675
|
-
// Returns the distance between `first` and `last`, as if
|
|
676
|
-
// `std::distance(first, last)` was called.
|
|
677
|
-
static ptrdiff_t Distance(const CharIterator& first,
|
|
678
|
-
const CharIterator& last);
|
|
679
|
-
|
|
680
|
-
// Cord::char_begin()
|
|
681
|
-
//
|
|
682
|
-
// Returns an iterator to the first character of the `Cord`.
|
|
683
|
-
//
|
|
684
|
-
// Generally, prefer using `Cord::Chars()` within a range-based for loop for
|
|
685
|
-
// iterating over the chunks of a Cord. This method may be useful for getting
|
|
686
|
-
// a `CharIterator` where range-based for-loops may not be available.
|
|
687
|
-
CharIterator char_begin() const ABSL_ATTRIBUTE_LIFETIME_BOUND;
|
|
688
|
-
|
|
689
|
-
// Cord::char_end()
|
|
690
|
-
//
|
|
691
|
-
// Returns an iterator to one past the last character of the `Cord`.
|
|
692
|
-
//
|
|
693
|
-
// Generally, prefer using `Cord::Chars()` within a range-based for loop for
|
|
694
|
-
// iterating over the chunks of a Cord. This method may be useful for getting
|
|
695
|
-
// a `CharIterator` where range-based for-loops are not useful.
|
|
696
|
-
CharIterator char_end() const ABSL_ATTRIBUTE_LIFETIME_BOUND;
|
|
697
|
-
|
|
698
|
-
// Cord::CharRange
|
|
699
|
-
//
|
|
700
|
-
// `CharRange` is a helper class for iterating over the characters of a
|
|
701
|
-
// producing an iterator which can be used within a range-based for loop.
|
|
702
|
-
// Construction of a `CharRange` will return an iterator pointing to the first
|
|
703
|
-
// character of the Cord. Generally, do not construct a `CharRange` directly;
|
|
704
|
-
// instead, prefer to use the `Cord::Chars()` method shown below.
|
|
705
|
-
//
|
|
706
|
-
// Implementation note: `CharRange` is simply a convenience wrapper over
|
|
707
|
-
// `Cord::char_begin()` and `Cord::char_end()`.
|
|
708
|
-
class CharRange {
|
|
709
|
-
public:
|
|
710
|
-
// Fulfill minimum c++ container requirements [container.requirements]
|
|
711
|
-
// These (partial) container type definitions allow CharRange to be used
|
|
712
|
-
// in various utilities expecting a subset of [container.requirements].
|
|
713
|
-
// For example, the below enables using `::testing::ElementsAre(...)`
|
|
714
|
-
using value_type = char;
|
|
715
|
-
using reference = value_type&;
|
|
716
|
-
using const_reference = const value_type&;
|
|
717
|
-
using iterator = CharIterator;
|
|
718
|
-
using const_iterator = CharIterator;
|
|
719
|
-
|
|
720
|
-
explicit CharRange(const Cord* absl_nonnull cord) : cord_(cord) {}
|
|
721
|
-
|
|
722
|
-
CharIterator begin() const;
|
|
723
|
-
CharIterator end() const;
|
|
724
|
-
|
|
725
|
-
private:
|
|
726
|
-
const Cord* absl_nonnull cord_;
|
|
727
|
-
};
|
|
728
|
-
|
|
729
|
-
// Cord::Chars()
|
|
730
|
-
//
|
|
731
|
-
// Returns a `Cord::CharRange` for iterating over the characters of a `Cord`
|
|
732
|
-
// with a range-based for-loop. For most character-based iteration tasks on a
|
|
733
|
-
// Cord, use `Cord::Chars()` to retrieve this iterator.
|
|
734
|
-
//
|
|
735
|
-
// Example:
|
|
736
|
-
//
|
|
737
|
-
// void ProcessCord(const Cord& cord) {
|
|
738
|
-
// for (char c : cord.Chars()) { ... }
|
|
739
|
-
// }
|
|
740
|
-
//
|
|
741
|
-
// Note that the ordinary caveats of temporary lifetime extension apply:
|
|
742
|
-
//
|
|
743
|
-
// void Process() {
|
|
744
|
-
// for (char c : CordFactory().Chars()) {
|
|
745
|
-
// // The temporary Cord returned by CordFactory has been destroyed!
|
|
746
|
-
// }
|
|
747
|
-
// }
|
|
748
|
-
CharRange Chars() const ABSL_ATTRIBUTE_LIFETIME_BOUND;
|
|
749
|
-
|
|
750
|
-
// Cord::operator[]
|
|
751
|
-
//
|
|
752
|
-
// Gets the "i"th character of the Cord and returns it, provided that
|
|
753
|
-
// 0 <= i < Cord.size().
|
|
754
|
-
//
|
|
755
|
-
// NOTE: This routine is reasonably efficient. It is roughly
|
|
756
|
-
// logarithmic based on the number of chunks that make up the cord. Still,
|
|
757
|
-
// if you need to iterate over the contents of a cord, you should
|
|
758
|
-
// use a CharIterator/ChunkIterator rather than call operator[]
|
|
759
|
-
// repeatedly in a loop.
|
|
760
|
-
char operator[](size_t i) const;
|
|
761
|
-
|
|
762
|
-
// Cord::TryFlat()
|
|
763
|
-
//
|
|
764
|
-
// If this cord's representation is a single flat array, returns a
|
|
765
|
-
// string_view referencing that array. Otherwise returns nullopt.
|
|
766
|
-
absl::optional<absl::string_view> TryFlat() const
|
|
767
|
-
ABSL_ATTRIBUTE_LIFETIME_BOUND;
|
|
768
|
-
|
|
769
|
-
// Cord::Flatten()
|
|
770
|
-
//
|
|
771
|
-
// Flattens the cord into a single array and returns a view of the data.
|
|
772
|
-
//
|
|
773
|
-
// If the cord was already flat, the contents are not modified.
|
|
774
|
-
absl::string_view Flatten() ABSL_ATTRIBUTE_LIFETIME_BOUND;
|
|
775
|
-
|
|
776
|
-
// Cord::Find()
|
|
777
|
-
//
|
|
778
|
-
// Returns an iterator to the first occurrence of the substring `needle`.
|
|
779
|
-
//
|
|
780
|
-
// If the substring `needle` does not occur, `Cord::char_end()` is returned.
|
|
781
|
-
CharIterator Find(absl::string_view needle) const;
|
|
782
|
-
CharIterator Find(const absl::Cord& needle) const;
|
|
783
|
-
|
|
784
|
-
// Supports absl::Cord as a sink object for absl::Format().
|
|
785
|
-
friend void AbslFormatFlush(absl::Cord* absl_nonnull cord,
|
|
786
|
-
absl::string_view part) {
|
|
787
|
-
cord->Append(part);
|
|
788
|
-
}
|
|
789
|
-
|
|
790
|
-
// Support automatic stringification with absl::StrCat and absl::StrFormat.
|
|
791
|
-
template <typename Sink>
|
|
792
|
-
friend void AbslStringify(Sink& sink, const absl::Cord& cord) {
|
|
793
|
-
for (absl::string_view chunk : cord.Chunks()) {
|
|
794
|
-
sink.Append(chunk);
|
|
795
|
-
}
|
|
796
|
-
}
|
|
797
|
-
|
|
798
|
-
// Cord::SetExpectedChecksum()
|
|
799
|
-
//
|
|
800
|
-
// Stores a checksum value with this non-empty cord instance, for later
|
|
801
|
-
// retrieval.
|
|
802
|
-
//
|
|
803
|
-
// The expected checksum is a number stored out-of-band, alongside the data.
|
|
804
|
-
// It is preserved across copies and assignments, but any mutations to a cord
|
|
805
|
-
// will cause it to lose its expected checksum.
|
|
806
|
-
//
|
|
807
|
-
// The expected checksum is not part of a Cord's value, and does not affect
|
|
808
|
-
// operations such as equality or hashing.
|
|
809
|
-
//
|
|
810
|
-
// This field is intended to store a CRC32C checksum for later validation, to
|
|
811
|
-
// help support end-to-end checksum workflows. However, the Cord API itself
|
|
812
|
-
// does no CRC validation, and assigns no meaning to this number.
|
|
813
|
-
//
|
|
814
|
-
// This call has no effect if this cord is empty.
|
|
815
|
-
void SetExpectedChecksum(uint32_t crc);
|
|
816
|
-
|
|
817
|
-
// Returns this cord's expected checksum, if it has one. Otherwise, returns
|
|
818
|
-
// nullopt.
|
|
819
|
-
absl::optional<uint32_t> ExpectedChecksum() const;
|
|
820
|
-
|
|
821
|
-
template <typename H>
|
|
822
|
-
friend H AbslHashValue(H hash_state, const absl::Cord& c) {
|
|
823
|
-
absl::optional<absl::string_view> maybe_flat = c.TryFlat();
|
|
824
|
-
if (maybe_flat.has_value()) {
|
|
825
|
-
return H::combine(std::move(hash_state), *maybe_flat);
|
|
826
|
-
}
|
|
827
|
-
return c.HashFragmented(std::move(hash_state));
|
|
828
|
-
}
|
|
829
|
-
|
|
830
|
-
// Create a Cord with the contents of StringConstant<T>::value.
|
|
831
|
-
// No allocations will be done and no data will be copied.
|
|
832
|
-
// This is an INTERNAL API and subject to change or removal. This API can only
|
|
833
|
-
// be used by spelling absl::strings_internal::MakeStringConstant, which is
|
|
834
|
-
// also an internal API.
|
|
835
|
-
template <typename T>
|
|
836
|
-
// NOLINTNEXTLINE(google-explicit-constructor)
|
|
837
|
-
constexpr Cord(strings_internal::StringConstant<T>);
|
|
838
|
-
|
|
839
|
-
private:
|
|
840
|
-
using CordRep = absl::cord_internal::CordRep;
|
|
841
|
-
using CordRepFlat = absl::cord_internal::CordRepFlat;
|
|
842
|
-
using CordzInfo = cord_internal::CordzInfo;
|
|
843
|
-
using CordzUpdateScope = cord_internal::CordzUpdateScope;
|
|
844
|
-
using CordzUpdateTracker = cord_internal::CordzUpdateTracker;
|
|
845
|
-
using InlineData = cord_internal::InlineData;
|
|
846
|
-
using MethodIdentifier = CordzUpdateTracker::MethodIdentifier;
|
|
847
|
-
|
|
848
|
-
// Creates a cord instance with `method` representing the originating
|
|
849
|
-
// public API call causing the cord to be created.
|
|
850
|
-
explicit Cord(absl::string_view src, MethodIdentifier method);
|
|
851
|
-
|
|
852
|
-
friend class CordTestPeer;
|
|
853
|
-
friend bool operator==(const Cord& lhs, const Cord& rhs);
|
|
854
|
-
friend bool operator==(const Cord& lhs, absl::string_view rhs);
|
|
855
|
-
|
|
856
|
-
#ifdef __cpp_impl_three_way_comparison
|
|
857
|
-
|
|
858
|
-
// Cords support comparison with other Cords and string_views via operator<
|
|
859
|
-
// and others; here we provide a wrapper for the C++20 three-way comparison
|
|
860
|
-
// <=> operator.
|
|
861
|
-
|
|
862
|
-
static inline std::strong_ordering ConvertCompareResultToStrongOrdering(
|
|
863
|
-
int c) {
|
|
864
|
-
if (c == 0) {
|
|
865
|
-
return std::strong_ordering::equal;
|
|
866
|
-
} else if (c < 0) {
|
|
867
|
-
return std::strong_ordering::less;
|
|
868
|
-
} else {
|
|
869
|
-
return std::strong_ordering::greater;
|
|
870
|
-
}
|
|
871
|
-
}
|
|
872
|
-
|
|
873
|
-
friend inline std::strong_ordering operator<=>(const Cord& x, const Cord& y) {
|
|
874
|
-
return ConvertCompareResultToStrongOrdering(x.Compare(y));
|
|
875
|
-
}
|
|
876
|
-
|
|
877
|
-
friend inline std::strong_ordering operator<=>(const Cord& lhs,
|
|
878
|
-
absl::string_view rhs) {
|
|
879
|
-
return ConvertCompareResultToStrongOrdering(lhs.Compare(rhs));
|
|
880
|
-
}
|
|
881
|
-
|
|
882
|
-
friend inline std::strong_ordering operator<=>(absl::string_view lhs,
|
|
883
|
-
const Cord& rhs) {
|
|
884
|
-
return ConvertCompareResultToStrongOrdering(-rhs.Compare(lhs));
|
|
885
|
-
}
|
|
886
|
-
#endif
|
|
887
|
-
|
|
888
|
-
friend const CordzInfo* absl_nullable GetCordzInfoForTesting(
|
|
889
|
-
const Cord& cord);
|
|
890
|
-
|
|
891
|
-
// Calls the provided function once for each cord chunk, in order. Unlike
|
|
892
|
-
// Chunks(), this API will not allocate memory.
|
|
893
|
-
void ForEachChunk(absl::FunctionRef<void(absl::string_view)>) const;
|
|
894
|
-
|
|
895
|
-
// Allocates new contiguous storage for the contents of the cord. This is
|
|
896
|
-
// called by Flatten() when the cord was not already flat.
|
|
897
|
-
absl::string_view FlattenSlowPath();
|
|
898
|
-
|
|
899
|
-
// Actual cord contents are hidden inside the following simple
|
|
900
|
-
// class so that we can isolate the bulk of cord.cc from changes
|
|
901
|
-
// to the representation.
|
|
902
|
-
//
|
|
903
|
-
// InlineRep holds either a tree pointer, or an array of kMaxInline bytes.
|
|
904
|
-
class InlineRep {
|
|
905
|
-
public:
|
|
906
|
-
static constexpr unsigned char kMaxInline = cord_internal::kMaxInline;
|
|
907
|
-
static_assert(kMaxInline >= sizeof(absl::cord_internal::CordRep*), "");
|
|
908
|
-
|
|
909
|
-
constexpr InlineRep() : data_() {}
|
|
910
|
-
explicit InlineRep(InlineData::DefaultInitType init) : data_(init) {}
|
|
911
|
-
InlineRep(const InlineRep& src);
|
|
912
|
-
InlineRep(InlineRep&& src);
|
|
913
|
-
InlineRep& operator=(const InlineRep& src);
|
|
914
|
-
InlineRep& operator=(InlineRep&& src) noexcept;
|
|
915
|
-
|
|
916
|
-
explicit constexpr InlineRep(absl::string_view sv,
|
|
917
|
-
CordRep* absl_nullable rep);
|
|
918
|
-
|
|
919
|
-
void Swap(InlineRep* absl_nonnull rhs);
|
|
920
|
-
size_t size() const;
|
|
921
|
-
// Returns nullptr if holding pointer
|
|
922
|
-
const char* absl_nullable data() const;
|
|
923
|
-
// Discards pointer, if any
|
|
924
|
-
void set_data(const char* absl_nullable data, size_t n);
|
|
925
|
-
char* absl_nonnull set_data(size_t n); // Write data to the result
|
|
926
|
-
// Returns nullptr if holding bytes
|
|
927
|
-
absl::cord_internal::CordRep* absl_nullable tree() const;
|
|
928
|
-
absl::cord_internal::CordRep* absl_nonnull as_tree() const;
|
|
929
|
-
const char* absl_nonnull as_chars() const;
|
|
930
|
-
// Returns non-null iff was holding a pointer
|
|
931
|
-
absl::cord_internal::CordRep* absl_nullable clear();
|
|
932
|
-
// Converts to pointer if necessary.
|
|
933
|
-
void reduce_size(size_t n); // REQUIRES: holding data
|
|
934
|
-
void remove_prefix(size_t n); // REQUIRES: holding data
|
|
935
|
-
void AppendArray(absl::string_view src, MethodIdentifier method);
|
|
936
|
-
absl::string_view FindFlatStartPiece() const;
|
|
937
|
-
|
|
938
|
-
// Creates a CordRepFlat instance from the current inlined data with `extra'
|
|
939
|
-
// bytes of desired additional capacity.
|
|
940
|
-
CordRepFlat* absl_nonnull MakeFlatWithExtraCapacity(size_t extra);
|
|
941
|
-
|
|
942
|
-
// Sets the tree value for this instance. `rep` must not be null.
|
|
943
|
-
// Requires the current instance to hold a tree, and a lock to be held on
|
|
944
|
-
// any CordzInfo referenced by this instance. The latter is enforced through
|
|
945
|
-
// the CordzUpdateScope argument. If the current instance is sampled, then
|
|
946
|
-
// the CordzInfo instance is updated to reference the new `rep` value.
|
|
947
|
-
void SetTree(CordRep* absl_nonnull rep, const CordzUpdateScope& scope);
|
|
948
|
-
|
|
949
|
-
// Identical to SetTree(), except that `rep` is allowed to be null, in
|
|
950
|
-
// which case the current instance is reset to an empty value.
|
|
951
|
-
void SetTreeOrEmpty(CordRep* absl_nullable rep,
|
|
952
|
-
const CordzUpdateScope& scope);
|
|
953
|
-
|
|
954
|
-
// Sets the tree value for this instance, and randomly samples this cord.
|
|
955
|
-
// This function disregards existing contents in `data_`, and should be
|
|
956
|
-
// called when a Cord is 'promoted' from an 'uninitialized' or 'inlined'
|
|
957
|
-
// value to a non-inlined (tree / ring) value.
|
|
958
|
-
void EmplaceTree(CordRep* absl_nonnull rep, MethodIdentifier method);
|
|
959
|
-
|
|
960
|
-
// Identical to EmplaceTree, except that it copies the parent stack from
|
|
961
|
-
// the provided `parent` data if the parent is sampled.
|
|
962
|
-
void EmplaceTree(CordRep* absl_nonnull rep, const InlineData& parent,
|
|
963
|
-
MethodIdentifier method);
|
|
964
|
-
|
|
965
|
-
// Commits the change of a newly created, or updated `rep` root value into
|
|
966
|
-
// this cord. `old_rep` indicates the old (inlined or tree) value of the
|
|
967
|
-
// cord, and determines if the commit invokes SetTree() or EmplaceTree().
|
|
968
|
-
void CommitTree(const CordRep* absl_nullable old_rep,
|
|
969
|
-
CordRep* absl_nonnull rep, const CordzUpdateScope& scope,
|
|
970
|
-
MethodIdentifier method);
|
|
971
|
-
|
|
972
|
-
void AppendTreeToInlined(CordRep* absl_nonnull tree,
|
|
973
|
-
MethodIdentifier method);
|
|
974
|
-
void AppendTreeToTree(CordRep* absl_nonnull tree, MethodIdentifier method);
|
|
975
|
-
void AppendTree(CordRep* absl_nonnull tree, MethodIdentifier method);
|
|
976
|
-
void PrependTreeToInlined(CordRep* absl_nonnull tree,
|
|
977
|
-
MethodIdentifier method);
|
|
978
|
-
void PrependTreeToTree(CordRep* absl_nonnull tree, MethodIdentifier method);
|
|
979
|
-
void PrependTree(CordRep* absl_nonnull tree, MethodIdentifier method);
|
|
980
|
-
|
|
981
|
-
bool IsSame(const InlineRep& other) const { return data_ == other.data_; }
|
|
982
|
-
|
|
983
|
-
// Copies the inline contents into `dst`. Assumes the cord is not empty.
|
|
984
|
-
void CopyTo(std::string* absl_nonnull dst) const {
|
|
985
|
-
data_.CopyInlineToString(dst);
|
|
986
|
-
}
|
|
987
|
-
|
|
988
|
-
// Copies the inline contents into `dst`. Assumes the cord is not empty.
|
|
989
|
-
void CopyToArray(char* absl_nonnull dst) const;
|
|
990
|
-
|
|
991
|
-
bool is_tree() const { return data_.is_tree(); }
|
|
992
|
-
|
|
993
|
-
// Returns true if the Cord is being profiled by cordz.
|
|
994
|
-
bool is_profiled() const { return data_.is_tree() && data_.is_profiled(); }
|
|
995
|
-
|
|
996
|
-
// Returns the available inlined capacity, or 0 if is_tree() == true.
|
|
997
|
-
size_t remaining_inline_capacity() const {
|
|
998
|
-
return data_.is_tree() ? 0 : kMaxInline - data_.inline_size();
|
|
999
|
-
}
|
|
1000
|
-
|
|
1001
|
-
// Returns the profiled CordzInfo, or nullptr if not sampled.
|
|
1002
|
-
absl::cord_internal::CordzInfo* absl_nullable cordz_info() const {
|
|
1003
|
-
return data_.cordz_info();
|
|
1004
|
-
}
|
|
1005
|
-
|
|
1006
|
-
// Sets the profiled CordzInfo.
|
|
1007
|
-
void set_cordz_info(cord_internal::CordzInfo* absl_nonnull cordz_info) {
|
|
1008
|
-
assert(cordz_info != nullptr);
|
|
1009
|
-
data_.set_cordz_info(cordz_info);
|
|
1010
|
-
}
|
|
1011
|
-
|
|
1012
|
-
// Resets the current cordz_info to null / empty.
|
|
1013
|
-
void clear_cordz_info() { data_.clear_cordz_info(); }
|
|
1014
|
-
|
|
1015
|
-
private:
|
|
1016
|
-
friend class Cord;
|
|
1017
|
-
|
|
1018
|
-
void AssignSlow(const InlineRep& src);
|
|
1019
|
-
// Unrefs the tree and stops profiling.
|
|
1020
|
-
void UnrefTree();
|
|
1021
|
-
|
|
1022
|
-
void ResetToEmpty() { data_ = {}; }
|
|
1023
|
-
|
|
1024
|
-
void set_inline_size(size_t size) { data_.set_inline_size(size); }
|
|
1025
|
-
size_t inline_size() const { return data_.inline_size(); }
|
|
1026
|
-
|
|
1027
|
-
// Empty cords that carry a checksum have a CordRepCrc node with a null
|
|
1028
|
-
// child node. The code can avoid lots of special cases where it would
|
|
1029
|
-
// otherwise transition from tree to inline storage if we just remove the
|
|
1030
|
-
// CordRepCrc node before mutations. Must never be called inside a
|
|
1031
|
-
// CordzUpdateScope since it untracks the cordz info.
|
|
1032
|
-
void MaybeRemoveEmptyCrcNode();
|
|
1033
|
-
|
|
1034
|
-
cord_internal::InlineData data_;
|
|
1035
|
-
};
|
|
1036
|
-
InlineRep contents_;
|
|
1037
|
-
|
|
1038
|
-
// Helper for GetFlat() and TryFlat().
|
|
1039
|
-
static bool GetFlatAux(absl::cord_internal::CordRep* absl_nonnull rep,
|
|
1040
|
-
absl::string_view* absl_nonnull fragment);
|
|
1041
|
-
|
|
1042
|
-
// Helper for ForEachChunk().
|
|
1043
|
-
static void ForEachChunkAux(
|
|
1044
|
-
absl::cord_internal::CordRep* absl_nonnull rep,
|
|
1045
|
-
absl::FunctionRef<void(absl::string_view)> callback);
|
|
1046
|
-
|
|
1047
|
-
// The destructor for non-empty Cords.
|
|
1048
|
-
void DestroyCordSlow();
|
|
1049
|
-
|
|
1050
|
-
// Out-of-line implementation of slower parts of logic.
|
|
1051
|
-
void CopyToArraySlowPath(char* absl_nonnull dst) const;
|
|
1052
|
-
int CompareSlowPath(absl::string_view rhs, size_t compared_size,
|
|
1053
|
-
size_t size_to_compare) const;
|
|
1054
|
-
int CompareSlowPath(const Cord& rhs, size_t compared_size,
|
|
1055
|
-
size_t size_to_compare) const;
|
|
1056
|
-
bool EqualsImpl(absl::string_view rhs, size_t size_to_compare) const;
|
|
1057
|
-
bool EqualsImpl(const Cord& rhs, size_t size_to_compare) const;
|
|
1058
|
-
int CompareImpl(const Cord& rhs) const;
|
|
1059
|
-
|
|
1060
|
-
template <typename ResultType, typename RHS>
|
|
1061
|
-
friend ResultType GenericCompare(const Cord& lhs, const RHS& rhs,
|
|
1062
|
-
size_t size_to_compare);
|
|
1063
|
-
static absl::string_view GetFirstChunk(const Cord& c);
|
|
1064
|
-
static absl::string_view GetFirstChunk(absl::string_view sv);
|
|
1065
|
-
|
|
1066
|
-
// Returns a new reference to contents_.tree(), or steals an existing
|
|
1067
|
-
// reference if called on an rvalue.
|
|
1068
|
-
absl::cord_internal::CordRep* absl_nonnull TakeRep() const&;
|
|
1069
|
-
absl::cord_internal::CordRep* absl_nonnull TakeRep() &&;
|
|
1070
|
-
|
|
1071
|
-
// Helper for Append().
|
|
1072
|
-
template <typename C>
|
|
1073
|
-
void AppendImpl(C&& src);
|
|
1074
|
-
|
|
1075
|
-
// Appends / Prepends `src` to this instance, using precise sizing.
|
|
1076
|
-
// This method does explicitly not attempt to use any spare capacity
|
|
1077
|
-
// in any pending last added private owned flat.
|
|
1078
|
-
// Requires `src` to be <= kMaxFlatLength.
|
|
1079
|
-
void AppendPrecise(absl::string_view src, MethodIdentifier method);
|
|
1080
|
-
void PrependPrecise(absl::string_view src, MethodIdentifier method);
|
|
1081
|
-
|
|
1082
|
-
CordBuffer GetAppendBufferSlowPath(size_t block_size, size_t capacity,
|
|
1083
|
-
size_t min_capacity);
|
|
1084
|
-
|
|
1085
|
-
// Prepends the provided data to this instance. `method` contains the public
|
|
1086
|
-
// API method for this action which is tracked for Cordz sampling purposes.
|
|
1087
|
-
void PrependArray(absl::string_view src, MethodIdentifier method);
|
|
1088
|
-
|
|
1089
|
-
// Assigns the value in 'src' to this instance, 'stealing' its contents.
|
|
1090
|
-
// Requires src.length() > kMaxBytesToCopy.
|
|
1091
|
-
Cord& AssignLargeString(std::string&& src);
|
|
1092
|
-
|
|
1093
|
-
// Helper for AbslHashValue().
|
|
1094
|
-
template <typename H>
|
|
1095
|
-
H HashFragmented(H hash_state) const {
|
|
1096
|
-
typename H::AbslInternalPiecewiseCombiner combiner;
|
|
1097
|
-
ForEachChunk([&combiner, &hash_state](absl::string_view chunk) {
|
|
1098
|
-
hash_state = combiner.add_buffer(std::move(hash_state), chunk.data(),
|
|
1099
|
-
chunk.size());
|
|
1100
|
-
});
|
|
1101
|
-
return combiner.finalize(std::move(hash_state));
|
|
1102
|
-
}
|
|
1103
|
-
|
|
1104
|
-
friend class CrcCord;
|
|
1105
|
-
void SetCrcCordState(crc_internal::CrcCordState state);
|
|
1106
|
-
const crc_internal::CrcCordState* absl_nullable MaybeGetCrcCordState() const;
|
|
1107
|
-
|
|
1108
|
-
CharIterator FindImpl(CharIterator it, absl::string_view needle) const;
|
|
1109
|
-
|
|
1110
|
-
void CopyToArrayImpl(char* absl_nonnull dst) const;
|
|
1111
|
-
};
|
|
1112
|
-
|
|
1113
|
-
ABSL_NAMESPACE_END
|
|
1114
|
-
} // namespace absl
|
|
1115
|
-
|
|
1116
|
-
namespace absl {
|
|
1117
|
-
ABSL_NAMESPACE_BEGIN
|
|
1118
|
-
|
|
1119
|
-
// allow a Cord to be logged
|
|
1120
|
-
extern std::ostream& operator<<(std::ostream& out, const Cord& cord);
|
|
1121
|
-
|
|
1122
|
-
// ------------------------------------------------------------------
|
|
1123
|
-
// Internal details follow. Clients should ignore.
|
|
1124
|
-
|
|
1125
|
-
namespace cord_internal {
|
|
1126
|
-
|
|
1127
|
-
// Does non-template-specific `CordRepExternal` initialization.
|
|
1128
|
-
// Requires `data` to be non-empty.
|
|
1129
|
-
void InitializeCordRepExternal(absl::string_view data,
|
|
1130
|
-
CordRepExternal* absl_nonnull rep);
|
|
1131
|
-
|
|
1132
|
-
// Creates a new `CordRep` that owns `data` and `releaser` and returns a pointer
|
|
1133
|
-
// to it. Requires `data` to be non-empty.
|
|
1134
|
-
template <typename Releaser>
|
|
1135
|
-
// NOLINTNEXTLINE - suppress clang-tidy raw pointer return.
|
|
1136
|
-
CordRep* absl_nonnull NewExternalRep(absl::string_view data,
|
|
1137
|
-
Releaser&& releaser) {
|
|
1138
|
-
assert(!data.empty());
|
|
1139
|
-
using ReleaserType = absl::decay_t<Releaser>;
|
|
1140
|
-
CordRepExternal* rep = new CordRepExternalImpl<ReleaserType>(
|
|
1141
|
-
std::forward<Releaser>(releaser), 0);
|
|
1142
|
-
InitializeCordRepExternal(data, rep);
|
|
1143
|
-
return rep;
|
|
1144
|
-
}
|
|
1145
|
-
|
|
1146
|
-
// Overload for function reference types that dispatches using a function
|
|
1147
|
-
// pointer because there are no `alignof()` or `sizeof()` a function reference.
|
|
1148
|
-
// NOLINTNEXTLINE - suppress clang-tidy raw pointer return.
|
|
1149
|
-
inline CordRep* absl_nonnull NewExternalRep(
|
|
1150
|
-
absl::string_view data, void (&releaser)(absl::string_view)) {
|
|
1151
|
-
return NewExternalRep(data, &releaser);
|
|
1152
|
-
}
|
|
1153
|
-
|
|
1154
|
-
} // namespace cord_internal
|
|
1155
|
-
|
|
1156
|
-
template <typename Releaser>
|
|
1157
|
-
Cord MakeCordFromExternal(absl::string_view data, Releaser&& releaser) {
|
|
1158
|
-
Cord cord;
|
|
1159
|
-
if (ABSL_PREDICT_TRUE(!data.empty())) {
|
|
1160
|
-
cord.contents_.EmplaceTree(::absl::cord_internal::NewExternalRep(
|
|
1161
|
-
data, std::forward<Releaser>(releaser)),
|
|
1162
|
-
Cord::MethodIdentifier::kMakeCordFromExternal);
|
|
1163
|
-
} else {
|
|
1164
|
-
using ReleaserType = absl::decay_t<Releaser>;
|
|
1165
|
-
cord_internal::InvokeReleaser(
|
|
1166
|
-
cord_internal::Rank1{}, ReleaserType(std::forward<Releaser>(releaser)),
|
|
1167
|
-
data);
|
|
1168
|
-
}
|
|
1169
|
-
return cord;
|
|
1170
|
-
}
|
|
1171
|
-
|
|
1172
|
-
constexpr Cord::InlineRep::InlineRep(absl::string_view sv,
|
|
1173
|
-
CordRep* absl_nullable rep)
|
|
1174
|
-
: data_(sv, rep) {}
|
|
1175
|
-
|
|
1176
|
-
inline Cord::InlineRep::InlineRep(const Cord::InlineRep& src)
|
|
1177
|
-
: data_(InlineData::kDefaultInit) {
|
|
1178
|
-
if (CordRep* tree = src.tree()) {
|
|
1179
|
-
EmplaceTree(CordRep::Ref(tree), src.data_,
|
|
1180
|
-
CordzUpdateTracker::kConstructorCord);
|
|
1181
|
-
} else {
|
|
1182
|
-
data_ = src.data_;
|
|
1183
|
-
}
|
|
1184
|
-
}
|
|
1185
|
-
|
|
1186
|
-
inline Cord::InlineRep::InlineRep(Cord::InlineRep&& src) : data_(src.data_) {
|
|
1187
|
-
src.ResetToEmpty();
|
|
1188
|
-
}
|
|
1189
|
-
|
|
1190
|
-
inline Cord::InlineRep& Cord::InlineRep::operator=(const Cord::InlineRep& src) {
|
|
1191
|
-
if (this == &src) {
|
|
1192
|
-
return *this;
|
|
1193
|
-
}
|
|
1194
|
-
if (!is_tree() && !src.is_tree()) {
|
|
1195
|
-
data_ = src.data_;
|
|
1196
|
-
return *this;
|
|
1197
|
-
}
|
|
1198
|
-
AssignSlow(src);
|
|
1199
|
-
return *this;
|
|
1200
|
-
}
|
|
1201
|
-
|
|
1202
|
-
inline Cord::InlineRep& Cord::InlineRep::operator=(
|
|
1203
|
-
Cord::InlineRep&& src) noexcept {
|
|
1204
|
-
if (is_tree()) {
|
|
1205
|
-
UnrefTree();
|
|
1206
|
-
}
|
|
1207
|
-
data_ = src.data_;
|
|
1208
|
-
src.ResetToEmpty();
|
|
1209
|
-
return *this;
|
|
1210
|
-
}
|
|
1211
|
-
|
|
1212
|
-
inline void Cord::InlineRep::Swap(Cord::InlineRep* absl_nonnull rhs) {
|
|
1213
|
-
if (rhs == this) {
|
|
1214
|
-
return;
|
|
1215
|
-
}
|
|
1216
|
-
using std::swap;
|
|
1217
|
-
swap(data_, rhs->data_);
|
|
1218
|
-
}
|
|
1219
|
-
|
|
1220
|
-
inline const char* absl_nullable Cord::InlineRep::data() const {
|
|
1221
|
-
return is_tree() ? nullptr : data_.as_chars();
|
|
1222
|
-
}
|
|
1223
|
-
|
|
1224
|
-
inline const char* absl_nonnull Cord::InlineRep::as_chars() const {
|
|
1225
|
-
assert(!data_.is_tree());
|
|
1226
|
-
return data_.as_chars();
|
|
1227
|
-
}
|
|
1228
|
-
|
|
1229
|
-
inline absl::cord_internal::CordRep* absl_nonnull Cord::InlineRep::as_tree()
|
|
1230
|
-
const {
|
|
1231
|
-
assert(data_.is_tree());
|
|
1232
|
-
return data_.as_tree();
|
|
1233
|
-
}
|
|
1234
|
-
|
|
1235
|
-
inline absl::cord_internal::CordRep* absl_nullable Cord::InlineRep::tree()
|
|
1236
|
-
const {
|
|
1237
|
-
if (is_tree()) {
|
|
1238
|
-
return as_tree();
|
|
1239
|
-
} else {
|
|
1240
|
-
return nullptr;
|
|
1241
|
-
}
|
|
1242
|
-
}
|
|
1243
|
-
|
|
1244
|
-
inline size_t Cord::InlineRep::size() const {
|
|
1245
|
-
return is_tree() ? as_tree()->length : inline_size();
|
|
1246
|
-
}
|
|
1247
|
-
|
|
1248
|
-
inline cord_internal::CordRepFlat* absl_nonnull
|
|
1249
|
-
Cord::InlineRep::MakeFlatWithExtraCapacity(size_t extra) {
|
|
1250
|
-
static_assert(cord_internal::kMinFlatLength >= sizeof(data_), "");
|
|
1251
|
-
size_t len = data_.inline_size();
|
|
1252
|
-
auto* result = CordRepFlat::New(len + extra);
|
|
1253
|
-
result->length = len;
|
|
1254
|
-
data_.copy_max_inline_to(result->Data());
|
|
1255
|
-
return result;
|
|
1256
|
-
}
|
|
1257
|
-
|
|
1258
|
-
inline void Cord::InlineRep::EmplaceTree(CordRep* absl_nonnull rep,
|
|
1259
|
-
MethodIdentifier method) {
|
|
1260
|
-
assert(rep);
|
|
1261
|
-
data_.make_tree(rep);
|
|
1262
|
-
CordzInfo::MaybeTrackCord(data_, method);
|
|
1263
|
-
}
|
|
1264
|
-
|
|
1265
|
-
inline void Cord::InlineRep::EmplaceTree(CordRep* absl_nonnull rep,
|
|
1266
|
-
const InlineData& parent,
|
|
1267
|
-
MethodIdentifier method) {
|
|
1268
|
-
data_.make_tree(rep);
|
|
1269
|
-
CordzInfo::MaybeTrackCord(data_, parent, method);
|
|
1270
|
-
}
|
|
1271
|
-
|
|
1272
|
-
inline void Cord::InlineRep::SetTree(CordRep* absl_nonnull rep,
|
|
1273
|
-
const CordzUpdateScope& scope) {
|
|
1274
|
-
assert(rep);
|
|
1275
|
-
assert(data_.is_tree());
|
|
1276
|
-
data_.set_tree(rep);
|
|
1277
|
-
scope.SetCordRep(rep);
|
|
1278
|
-
}
|
|
1279
|
-
|
|
1280
|
-
inline void Cord::InlineRep::SetTreeOrEmpty(CordRep* absl_nullable rep,
|
|
1281
|
-
const CordzUpdateScope& scope) {
|
|
1282
|
-
assert(data_.is_tree());
|
|
1283
|
-
if (rep) {
|
|
1284
|
-
data_.set_tree(rep);
|
|
1285
|
-
} else {
|
|
1286
|
-
data_ = {};
|
|
1287
|
-
}
|
|
1288
|
-
scope.SetCordRep(rep);
|
|
1289
|
-
}
|
|
1290
|
-
|
|
1291
|
-
inline void Cord::InlineRep::CommitTree(const CordRep* absl_nullable old_rep,
|
|
1292
|
-
CordRep* absl_nonnull rep,
|
|
1293
|
-
const CordzUpdateScope& scope,
|
|
1294
|
-
MethodIdentifier method) {
|
|
1295
|
-
if (old_rep) {
|
|
1296
|
-
SetTree(rep, scope);
|
|
1297
|
-
} else {
|
|
1298
|
-
EmplaceTree(rep, method);
|
|
1299
|
-
}
|
|
1300
|
-
}
|
|
1301
|
-
|
|
1302
|
-
inline absl::cord_internal::CordRep* absl_nullable Cord::InlineRep::clear() {
|
|
1303
|
-
if (is_tree()) {
|
|
1304
|
-
CordzInfo::MaybeUntrackCord(cordz_info());
|
|
1305
|
-
}
|
|
1306
|
-
absl::cord_internal::CordRep* result = tree();
|
|
1307
|
-
ResetToEmpty();
|
|
1308
|
-
return result;
|
|
1309
|
-
}
|
|
1310
|
-
|
|
1311
|
-
inline void Cord::InlineRep::CopyToArray(char* absl_nonnull dst) const {
|
|
1312
|
-
assert(!is_tree());
|
|
1313
|
-
size_t n = inline_size();
|
|
1314
|
-
assert(n != 0);
|
|
1315
|
-
cord_internal::SmallMemmove(dst, data_.as_chars(), n);
|
|
1316
|
-
}
|
|
1317
|
-
|
|
1318
|
-
inline void Cord::InlineRep::MaybeRemoveEmptyCrcNode() {
|
|
1319
|
-
CordRep* rep = tree();
|
|
1320
|
-
if (rep == nullptr || ABSL_PREDICT_TRUE(rep->length > 0)) {
|
|
1321
|
-
return;
|
|
1322
|
-
}
|
|
1323
|
-
assert(rep->IsCrc());
|
|
1324
|
-
assert(rep->crc()->child == nullptr);
|
|
1325
|
-
CordzInfo::MaybeUntrackCord(cordz_info());
|
|
1326
|
-
CordRep::Unref(rep);
|
|
1327
|
-
ResetToEmpty();
|
|
1328
|
-
}
|
|
1329
|
-
|
|
1330
|
-
constexpr inline Cord::Cord() noexcept {}
|
|
1331
|
-
|
|
1332
|
-
inline Cord::Cord(absl::string_view src)
|
|
1333
|
-
: Cord(src, CordzUpdateTracker::kConstructorString) {}
|
|
1334
|
-
|
|
1335
|
-
template <typename T>
|
|
1336
|
-
constexpr Cord::Cord(strings_internal::StringConstant<T>)
|
|
1337
|
-
: contents_(strings_internal::StringConstant<T>::value,
|
|
1338
|
-
strings_internal::StringConstant<T>::value.size() <=
|
|
1339
|
-
cord_internal::kMaxInline
|
|
1340
|
-
? nullptr
|
|
1341
|
-
: &cord_internal::ConstInitExternalStorage<
|
|
1342
|
-
strings_internal::StringConstant<T>>::value) {}
|
|
1343
|
-
|
|
1344
|
-
inline Cord& Cord::operator=(const Cord& x) {
|
|
1345
|
-
contents_ = x.contents_;
|
|
1346
|
-
return *this;
|
|
1347
|
-
}
|
|
1348
|
-
|
|
1349
|
-
template <typename T, Cord::EnableIfString<T>>
|
|
1350
|
-
Cord& Cord::operator=(T&& src) {
|
|
1351
|
-
if (src.size() <= cord_internal::kMaxBytesToCopy) {
|
|
1352
|
-
return operator=(absl::string_view(src));
|
|
1353
|
-
} else {
|
|
1354
|
-
return AssignLargeString(std::forward<T>(src));
|
|
1355
|
-
}
|
|
1356
|
-
}
|
|
1357
|
-
|
|
1358
|
-
inline Cord::Cord(const Cord& src) : contents_(src.contents_) {}
|
|
1359
|
-
|
|
1360
|
-
inline Cord::Cord(Cord&& src) noexcept : contents_(std::move(src.contents_)) {}
|
|
1361
|
-
|
|
1362
|
-
inline void Cord::swap(Cord& other) noexcept {
|
|
1363
|
-
contents_.Swap(&other.contents_);
|
|
1364
|
-
}
|
|
1365
|
-
|
|
1366
|
-
inline Cord& Cord::operator=(Cord&& x) noexcept {
|
|
1367
|
-
contents_ = std::move(x.contents_);
|
|
1368
|
-
return *this;
|
|
1369
|
-
}
|
|
1370
|
-
|
|
1371
|
-
extern template Cord::Cord(std::string&& src);
|
|
1372
|
-
|
|
1373
|
-
inline size_t Cord::size() const {
|
|
1374
|
-
// Length is 1st field in str.rep_
|
|
1375
|
-
return contents_.size();
|
|
1376
|
-
}
|
|
1377
|
-
|
|
1378
|
-
inline bool Cord::empty() const { return size() == 0; }
|
|
1379
|
-
|
|
1380
|
-
inline size_t Cord::EstimatedMemoryUsage(
|
|
1381
|
-
CordMemoryAccounting accounting_method) const {
|
|
1382
|
-
size_t result = sizeof(Cord);
|
|
1383
|
-
if (const absl::cord_internal::CordRep* rep = contents_.tree()) {
|
|
1384
|
-
switch (accounting_method) {
|
|
1385
|
-
case CordMemoryAccounting::kFairShare:
|
|
1386
|
-
result += cord_internal::GetEstimatedFairShareMemoryUsage(rep);
|
|
1387
|
-
break;
|
|
1388
|
-
case CordMemoryAccounting::kTotalMorePrecise:
|
|
1389
|
-
result += cord_internal::GetMorePreciseMemoryUsage(rep);
|
|
1390
|
-
break;
|
|
1391
|
-
case CordMemoryAccounting::kTotal:
|
|
1392
|
-
result += cord_internal::GetEstimatedMemoryUsage(rep);
|
|
1393
|
-
break;
|
|
1394
|
-
}
|
|
1395
|
-
}
|
|
1396
|
-
return result;
|
|
1397
|
-
}
|
|
1398
|
-
|
|
1399
|
-
inline absl::optional<absl::string_view> Cord::TryFlat() const
|
|
1400
|
-
ABSL_ATTRIBUTE_LIFETIME_BOUND {
|
|
1401
|
-
absl::cord_internal::CordRep* rep = contents_.tree();
|
|
1402
|
-
if (rep == nullptr) {
|
|
1403
|
-
return absl::string_view(contents_.data(), contents_.size());
|
|
1404
|
-
}
|
|
1405
|
-
absl::string_view fragment;
|
|
1406
|
-
if (GetFlatAux(rep, &fragment)) {
|
|
1407
|
-
return fragment;
|
|
1408
|
-
}
|
|
1409
|
-
return absl::nullopt;
|
|
1410
|
-
}
|
|
1411
|
-
|
|
1412
|
-
inline absl::string_view Cord::Flatten() ABSL_ATTRIBUTE_LIFETIME_BOUND {
|
|
1413
|
-
absl::cord_internal::CordRep* rep = contents_.tree();
|
|
1414
|
-
if (rep == nullptr) {
|
|
1415
|
-
return absl::string_view(contents_.data(), contents_.size());
|
|
1416
|
-
} else {
|
|
1417
|
-
absl::string_view already_flat_contents;
|
|
1418
|
-
if (GetFlatAux(rep, &already_flat_contents)) {
|
|
1419
|
-
return already_flat_contents;
|
|
1420
|
-
}
|
|
1421
|
-
}
|
|
1422
|
-
return FlattenSlowPath();
|
|
1423
|
-
}
|
|
1424
|
-
|
|
1425
|
-
inline void Cord::Append(absl::string_view src) {
|
|
1426
|
-
contents_.AppendArray(src, CordzUpdateTracker::kAppendString);
|
|
1427
|
-
}
|
|
1428
|
-
|
|
1429
|
-
inline void Cord::Prepend(absl::string_view src) {
|
|
1430
|
-
PrependArray(src, CordzUpdateTracker::kPrependString);
|
|
1431
|
-
}
|
|
1432
|
-
|
|
1433
|
-
inline void Cord::Append(CordBuffer buffer) {
|
|
1434
|
-
if (ABSL_PREDICT_FALSE(buffer.length() == 0)) return;
|
|
1435
|
-
contents_.MaybeRemoveEmptyCrcNode();
|
|
1436
|
-
absl::string_view short_value;
|
|
1437
|
-
if (CordRep* rep = buffer.ConsumeValue(short_value)) {
|
|
1438
|
-
contents_.AppendTree(rep, CordzUpdateTracker::kAppendCordBuffer);
|
|
1439
|
-
} else {
|
|
1440
|
-
AppendPrecise(short_value, CordzUpdateTracker::kAppendCordBuffer);
|
|
1441
|
-
}
|
|
1442
|
-
}
|
|
1443
|
-
|
|
1444
|
-
inline void Cord::Prepend(CordBuffer buffer) {
|
|
1445
|
-
if (ABSL_PREDICT_FALSE(buffer.length() == 0)) return;
|
|
1446
|
-
contents_.MaybeRemoveEmptyCrcNode();
|
|
1447
|
-
absl::string_view short_value;
|
|
1448
|
-
if (CordRep* rep = buffer.ConsumeValue(short_value)) {
|
|
1449
|
-
contents_.PrependTree(rep, CordzUpdateTracker::kPrependCordBuffer);
|
|
1450
|
-
} else {
|
|
1451
|
-
PrependPrecise(short_value, CordzUpdateTracker::kPrependCordBuffer);
|
|
1452
|
-
}
|
|
1453
|
-
}
|
|
1454
|
-
|
|
1455
|
-
inline CordBuffer Cord::GetAppendBuffer(size_t capacity, size_t min_capacity) {
|
|
1456
|
-
if (empty()) return CordBuffer::CreateWithDefaultLimit(capacity);
|
|
1457
|
-
return GetAppendBufferSlowPath(0, capacity, min_capacity);
|
|
1458
|
-
}
|
|
1459
|
-
|
|
1460
|
-
inline CordBuffer Cord::GetCustomAppendBuffer(size_t block_size,
|
|
1461
|
-
size_t capacity,
|
|
1462
|
-
size_t min_capacity) {
|
|
1463
|
-
if (empty()) {
|
|
1464
|
-
return block_size ? CordBuffer::CreateWithCustomLimit(block_size, capacity)
|
|
1465
|
-
: CordBuffer::CreateWithDefaultLimit(capacity);
|
|
1466
|
-
}
|
|
1467
|
-
return GetAppendBufferSlowPath(block_size, capacity, min_capacity);
|
|
1468
|
-
}
|
|
1469
|
-
|
|
1470
|
-
extern template void Cord::Append(std::string&& src);
|
|
1471
|
-
extern template void Cord::Prepend(std::string&& src);
|
|
1472
|
-
|
|
1473
|
-
inline int Cord::Compare(const Cord& rhs) const {
|
|
1474
|
-
if (!contents_.is_tree() && !rhs.contents_.is_tree()) {
|
|
1475
|
-
return contents_.data_.Compare(rhs.contents_.data_);
|
|
1476
|
-
}
|
|
1477
|
-
|
|
1478
|
-
return CompareImpl(rhs);
|
|
1479
|
-
}
|
|
1480
|
-
|
|
1481
|
-
// Does 'this' cord start/end with rhs
|
|
1482
|
-
inline bool Cord::StartsWith(const Cord& rhs) const {
|
|
1483
|
-
if (contents_.IsSame(rhs.contents_)) return true;
|
|
1484
|
-
size_t rhs_size = rhs.size();
|
|
1485
|
-
if (size() < rhs_size) return false;
|
|
1486
|
-
return EqualsImpl(rhs, rhs_size);
|
|
1487
|
-
}
|
|
1488
|
-
|
|
1489
|
-
inline bool Cord::StartsWith(absl::string_view rhs) const {
|
|
1490
|
-
size_t rhs_size = rhs.size();
|
|
1491
|
-
if (size() < rhs_size) return false;
|
|
1492
|
-
return EqualsImpl(rhs, rhs_size);
|
|
1493
|
-
}
|
|
1494
|
-
|
|
1495
|
-
inline void Cord::CopyToArrayImpl(char* absl_nonnull dst) const {
|
|
1496
|
-
if (!contents_.is_tree()) {
|
|
1497
|
-
if (!empty()) contents_.CopyToArray(dst);
|
|
1498
|
-
} else {
|
|
1499
|
-
CopyToArraySlowPath(dst);
|
|
1500
|
-
}
|
|
1501
|
-
}
|
|
1502
|
-
|
|
1503
|
-
inline void Cord::ChunkIterator::InitTree(
|
|
1504
|
-
cord_internal::CordRep* absl_nonnull tree) {
|
|
1505
|
-
tree = cord_internal::SkipCrcNode(tree);
|
|
1506
|
-
if (tree->tag == cord_internal::BTREE) {
|
|
1507
|
-
current_chunk_ = btree_reader_.Init(tree->btree());
|
|
1508
|
-
} else {
|
|
1509
|
-
current_leaf_ = tree;
|
|
1510
|
-
current_chunk_ = cord_internal::EdgeData(tree);
|
|
1511
|
-
}
|
|
1512
|
-
}
|
|
1513
|
-
|
|
1514
|
-
inline Cord::ChunkIterator::ChunkIterator(
|
|
1515
|
-
cord_internal::CordRep* absl_nonnull tree) {
|
|
1516
|
-
bytes_remaining_ = tree->length;
|
|
1517
|
-
InitTree(tree);
|
|
1518
|
-
}
|
|
1519
|
-
|
|
1520
|
-
inline Cord::ChunkIterator::ChunkIterator(const Cord* absl_nonnull cord) {
|
|
1521
|
-
if (CordRep* tree = cord->contents_.tree()) {
|
|
1522
|
-
bytes_remaining_ = tree->length;
|
|
1523
|
-
if (ABSL_PREDICT_TRUE(bytes_remaining_ != 0)) {
|
|
1524
|
-
InitTree(tree);
|
|
1525
|
-
} else {
|
|
1526
|
-
current_chunk_ = {};
|
|
1527
|
-
}
|
|
1528
|
-
} else {
|
|
1529
|
-
bytes_remaining_ = cord->contents_.inline_size();
|
|
1530
|
-
current_chunk_ = {cord->contents_.data(), bytes_remaining_};
|
|
1531
|
-
}
|
|
1532
|
-
}
|
|
1533
|
-
|
|
1534
|
-
inline Cord::ChunkIterator& Cord::ChunkIterator::AdvanceBtree() {
|
|
1535
|
-
current_chunk_ = btree_reader_.Next();
|
|
1536
|
-
return *this;
|
|
1537
|
-
}
|
|
1538
|
-
|
|
1539
|
-
inline void Cord::ChunkIterator::AdvanceBytesBtree(size_t n) {
|
|
1540
|
-
assert(n >= current_chunk_.size());
|
|
1541
|
-
bytes_remaining_ -= n;
|
|
1542
|
-
if (bytes_remaining_) {
|
|
1543
|
-
if (n == current_chunk_.size()) {
|
|
1544
|
-
current_chunk_ = btree_reader_.Next();
|
|
1545
|
-
} else {
|
|
1546
|
-
size_t offset = btree_reader_.length() - bytes_remaining_;
|
|
1547
|
-
current_chunk_ = btree_reader_.Seek(offset);
|
|
1548
|
-
}
|
|
1549
|
-
} else {
|
|
1550
|
-
current_chunk_ = {};
|
|
1551
|
-
}
|
|
1552
|
-
}
|
|
1553
|
-
|
|
1554
|
-
inline Cord::ChunkIterator& Cord::ChunkIterator::operator++() {
|
|
1555
|
-
ABSL_HARDENING_ASSERT(bytes_remaining_ > 0 &&
|
|
1556
|
-
"Attempted to iterate past `end()`");
|
|
1557
|
-
assert(bytes_remaining_ >= current_chunk_.size());
|
|
1558
|
-
bytes_remaining_ -= current_chunk_.size();
|
|
1559
|
-
if (bytes_remaining_ > 0) {
|
|
1560
|
-
if (btree_reader_) {
|
|
1561
|
-
return AdvanceBtree();
|
|
1562
|
-
} else {
|
|
1563
|
-
assert(!current_chunk_.empty()); // Called on invalid iterator.
|
|
1564
|
-
}
|
|
1565
|
-
current_chunk_ = {};
|
|
1566
|
-
}
|
|
1567
|
-
return *this;
|
|
1568
|
-
}
|
|
1569
|
-
|
|
1570
|
-
inline Cord::ChunkIterator Cord::ChunkIterator::operator++(int) {
|
|
1571
|
-
ChunkIterator tmp(*this);
|
|
1572
|
-
operator++();
|
|
1573
|
-
return tmp;
|
|
1574
|
-
}
|
|
1575
|
-
|
|
1576
|
-
inline bool Cord::ChunkIterator::operator==(const ChunkIterator& other) const {
|
|
1577
|
-
return bytes_remaining_ == other.bytes_remaining_;
|
|
1578
|
-
}
|
|
1579
|
-
|
|
1580
|
-
inline bool Cord::ChunkIterator::operator!=(const ChunkIterator& other) const {
|
|
1581
|
-
return !(*this == other);
|
|
1582
|
-
}
|
|
1583
|
-
|
|
1584
|
-
inline Cord::ChunkIterator::reference Cord::ChunkIterator::operator*() const {
|
|
1585
|
-
ABSL_HARDENING_ASSERT(bytes_remaining_ != 0);
|
|
1586
|
-
return current_chunk_;
|
|
1587
|
-
}
|
|
1588
|
-
|
|
1589
|
-
inline Cord::ChunkIterator::pointer Cord::ChunkIterator::operator->() const {
|
|
1590
|
-
ABSL_HARDENING_ASSERT(bytes_remaining_ != 0);
|
|
1591
|
-
return ¤t_chunk_;
|
|
1592
|
-
}
|
|
1593
|
-
|
|
1594
|
-
inline void Cord::ChunkIterator::RemoveChunkPrefix(size_t n) {
|
|
1595
|
-
assert(n < current_chunk_.size());
|
|
1596
|
-
current_chunk_.remove_prefix(n);
|
|
1597
|
-
bytes_remaining_ -= n;
|
|
1598
|
-
}
|
|
1599
|
-
|
|
1600
|
-
inline void Cord::ChunkIterator::AdvanceBytes(size_t n) {
|
|
1601
|
-
assert(bytes_remaining_ >= n);
|
|
1602
|
-
if (ABSL_PREDICT_TRUE(n < current_chunk_.size())) {
|
|
1603
|
-
RemoveChunkPrefix(n);
|
|
1604
|
-
} else if (n != 0) {
|
|
1605
|
-
if (btree_reader_) {
|
|
1606
|
-
AdvanceBytesBtree(n);
|
|
1607
|
-
} else {
|
|
1608
|
-
bytes_remaining_ = 0;
|
|
1609
|
-
}
|
|
1610
|
-
}
|
|
1611
|
-
}
|
|
1612
|
-
|
|
1613
|
-
inline Cord::ChunkIterator Cord::chunk_begin() const {
|
|
1614
|
-
return ChunkIterator(this);
|
|
1615
|
-
}
|
|
1616
|
-
|
|
1617
|
-
inline Cord::ChunkIterator Cord::chunk_end() const { return ChunkIterator(); }
|
|
1618
|
-
|
|
1619
|
-
inline Cord::ChunkIterator Cord::ChunkRange::begin() const {
|
|
1620
|
-
return cord_->chunk_begin();
|
|
1621
|
-
}
|
|
1622
|
-
|
|
1623
|
-
inline Cord::ChunkIterator Cord::ChunkRange::end() const {
|
|
1624
|
-
return cord_->chunk_end();
|
|
1625
|
-
}
|
|
1626
|
-
|
|
1627
|
-
inline Cord::ChunkRange Cord::Chunks() const { return ChunkRange(this); }
|
|
1628
|
-
|
|
1629
|
-
inline Cord::CharIterator& Cord::CharIterator::operator++() {
|
|
1630
|
-
if (ABSL_PREDICT_TRUE(chunk_iterator_->size() > 1)) {
|
|
1631
|
-
chunk_iterator_.RemoveChunkPrefix(1);
|
|
1632
|
-
} else {
|
|
1633
|
-
++chunk_iterator_;
|
|
1634
|
-
}
|
|
1635
|
-
return *this;
|
|
1636
|
-
}
|
|
1637
|
-
|
|
1638
|
-
inline Cord::CharIterator Cord::CharIterator::operator++(int) {
|
|
1639
|
-
CharIterator tmp(*this);
|
|
1640
|
-
operator++();
|
|
1641
|
-
return tmp;
|
|
1642
|
-
}
|
|
1643
|
-
|
|
1644
|
-
inline bool Cord::CharIterator::operator==(const CharIterator& other) const {
|
|
1645
|
-
return chunk_iterator_ == other.chunk_iterator_;
|
|
1646
|
-
}
|
|
1647
|
-
|
|
1648
|
-
inline bool Cord::CharIterator::operator!=(const CharIterator& other) const {
|
|
1649
|
-
return !(*this == other);
|
|
1650
|
-
}
|
|
1651
|
-
|
|
1652
|
-
inline Cord::CharIterator::reference Cord::CharIterator::operator*() const {
|
|
1653
|
-
return *chunk_iterator_->data();
|
|
1654
|
-
}
|
|
1655
|
-
|
|
1656
|
-
inline Cord Cord::AdvanceAndRead(CharIterator* absl_nonnull it,
|
|
1657
|
-
size_t n_bytes) {
|
|
1658
|
-
assert(it != nullptr);
|
|
1659
|
-
return it->chunk_iterator_.AdvanceAndReadBytes(n_bytes);
|
|
1660
|
-
}
|
|
1661
|
-
|
|
1662
|
-
inline void Cord::Advance(CharIterator* absl_nonnull it, size_t n_bytes) {
|
|
1663
|
-
assert(it != nullptr);
|
|
1664
|
-
it->chunk_iterator_.AdvanceBytes(n_bytes);
|
|
1665
|
-
}
|
|
1666
|
-
|
|
1667
|
-
inline absl::string_view Cord::ChunkRemaining(const CharIterator& it) {
|
|
1668
|
-
return *it.chunk_iterator_;
|
|
1669
|
-
}
|
|
1670
|
-
|
|
1671
|
-
inline ptrdiff_t Cord::Distance(const CharIterator& first,
|
|
1672
|
-
const CharIterator& last) {
|
|
1673
|
-
return static_cast<ptrdiff_t>(first.chunk_iterator_.bytes_remaining_ -
|
|
1674
|
-
last.chunk_iterator_.bytes_remaining_);
|
|
1675
|
-
}
|
|
1676
|
-
|
|
1677
|
-
inline Cord::CharIterator Cord::char_begin() const {
|
|
1678
|
-
return CharIterator(this);
|
|
1679
|
-
}
|
|
1680
|
-
|
|
1681
|
-
inline Cord::CharIterator Cord::char_end() const { return CharIterator(); }
|
|
1682
|
-
|
|
1683
|
-
inline Cord::CharIterator Cord::CharRange::begin() const {
|
|
1684
|
-
return cord_->char_begin();
|
|
1685
|
-
}
|
|
1686
|
-
|
|
1687
|
-
inline Cord::CharIterator Cord::CharRange::end() const {
|
|
1688
|
-
return cord_->char_end();
|
|
1689
|
-
}
|
|
1690
|
-
|
|
1691
|
-
inline Cord::CharRange Cord::Chars() const { return CharRange(this); }
|
|
1692
|
-
|
|
1693
|
-
inline void Cord::ForEachChunk(
|
|
1694
|
-
absl::FunctionRef<void(absl::string_view)> callback) const {
|
|
1695
|
-
absl::cord_internal::CordRep* rep = contents_.tree();
|
|
1696
|
-
if (rep == nullptr) {
|
|
1697
|
-
callback(absl::string_view(contents_.data(), contents_.size()));
|
|
1698
|
-
} else {
|
|
1699
|
-
ForEachChunkAux(rep, callback);
|
|
1700
|
-
}
|
|
1701
|
-
}
|
|
1702
|
-
|
|
1703
|
-
// Nonmember Cord-to-Cord relational operators.
|
|
1704
|
-
inline bool operator==(const Cord& lhs, const Cord& rhs) {
|
|
1705
|
-
if (lhs.contents_.IsSame(rhs.contents_)) return true;
|
|
1706
|
-
size_t rhs_size = rhs.size();
|
|
1707
|
-
if (lhs.size() != rhs_size) return false;
|
|
1708
|
-
return lhs.EqualsImpl(rhs, rhs_size);
|
|
1709
|
-
}
|
|
1710
|
-
|
|
1711
|
-
inline bool operator!=(const Cord& x, const Cord& y) { return !(x == y); }
|
|
1712
|
-
inline bool operator<(const Cord& x, const Cord& y) { return x.Compare(y) < 0; }
|
|
1713
|
-
inline bool operator>(const Cord& x, const Cord& y) { return x.Compare(y) > 0; }
|
|
1714
|
-
inline bool operator<=(const Cord& x, const Cord& y) {
|
|
1715
|
-
return x.Compare(y) <= 0;
|
|
1716
|
-
}
|
|
1717
|
-
inline bool operator>=(const Cord& x, const Cord& y) {
|
|
1718
|
-
return x.Compare(y) >= 0;
|
|
1719
|
-
}
|
|
1720
|
-
|
|
1721
|
-
// Nonmember Cord-to-absl::string_view relational operators.
|
|
1722
|
-
//
|
|
1723
|
-
// Due to implicit conversions, these also enable comparisons of Cord with
|
|
1724
|
-
// std::string and const char*.
|
|
1725
|
-
inline bool operator==(const Cord& lhs, absl::string_view rhs) {
|
|
1726
|
-
size_t lhs_size = lhs.size();
|
|
1727
|
-
size_t rhs_size = rhs.size();
|
|
1728
|
-
if (lhs_size != rhs_size) return false;
|
|
1729
|
-
return lhs.EqualsImpl(rhs, rhs_size);
|
|
1730
|
-
}
|
|
1731
|
-
|
|
1732
|
-
inline bool operator==(absl::string_view x, const Cord& y) { return y == x; }
|
|
1733
|
-
inline bool operator!=(const Cord& x, absl::string_view y) { return !(x == y); }
|
|
1734
|
-
inline bool operator!=(absl::string_view x, const Cord& y) { return !(x == y); }
|
|
1735
|
-
inline bool operator<(const Cord& x, absl::string_view y) {
|
|
1736
|
-
return x.Compare(y) < 0;
|
|
1737
|
-
}
|
|
1738
|
-
inline bool operator<(absl::string_view x, const Cord& y) {
|
|
1739
|
-
return y.Compare(x) > 0;
|
|
1740
|
-
}
|
|
1741
|
-
inline bool operator>(const Cord& x, absl::string_view y) { return y < x; }
|
|
1742
|
-
inline bool operator>(absl::string_view x, const Cord& y) { return y < x; }
|
|
1743
|
-
inline bool operator<=(const Cord& x, absl::string_view y) { return !(y < x); }
|
|
1744
|
-
inline bool operator<=(absl::string_view x, const Cord& y) { return !(y < x); }
|
|
1745
|
-
inline bool operator>=(const Cord& x, absl::string_view y) { return !(x < y); }
|
|
1746
|
-
inline bool operator>=(absl::string_view x, const Cord& y) { return !(x < y); }
|
|
1747
|
-
|
|
1748
|
-
// Some internals exposed to test code.
|
|
1749
|
-
namespace strings_internal {
|
|
1750
|
-
class CordTestAccess {
|
|
1751
|
-
public:
|
|
1752
|
-
static size_t FlatOverhead();
|
|
1753
|
-
static size_t MaxFlatLength();
|
|
1754
|
-
static size_t SizeofCordRepExternal();
|
|
1755
|
-
static size_t SizeofCordRepSubstring();
|
|
1756
|
-
static size_t FlatTagToLength(uint8_t tag);
|
|
1757
|
-
static uint8_t LengthToTag(size_t s);
|
|
1758
|
-
};
|
|
1759
|
-
} // namespace strings_internal
|
|
1760
|
-
ABSL_NAMESPACE_END
|
|
1761
|
-
} // namespace absl
|
|
1762
|
-
|
|
1763
|
-
#endif // ABSL_STRINGS_CORD_H_
|