@nxtedition/rocksdb 15.1.5 → 15.2.1

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.
Files changed (1705) hide show
  1. package/.claude/settings.local.json +5 -1
  2. package/binding.cc +84 -47
  3. package/binding.gyp +102 -2
  4. package/deps/abseil-cpp/BUILD.bazel +35 -0
  5. package/deps/abseil-cpp/CMake/AbseilDll.cmake +938 -0
  6. package/deps/abseil-cpp/CMake/AbseilHelpers.cmake +465 -0
  7. package/deps/abseil-cpp/CMake/Googletest/CMakeLists.txt.in +14 -0
  8. package/deps/abseil-cpp/CMake/Googletest/DownloadGTest.cmake +41 -0
  9. package/deps/abseil-cpp/CMake/abslConfig.cmake.in +8 -0
  10. package/deps/abseil-cpp/CMake/install_test_project/CMakeLists.txt +25 -0
  11. package/deps/abseil-cpp/CMake/install_test_project/simple.cc +32 -0
  12. package/deps/abseil-cpp/CMake/install_test_project/test.sh +113 -0
  13. package/deps/abseil-cpp/CMakeLists.txt +280 -0
  14. package/deps/abseil-cpp/LICENSE +203 -0
  15. package/deps/abseil-cpp/MODULE.bazel +43 -0
  16. package/deps/abseil-cpp/PrivacyInfo.xcprivacy +14 -0
  17. package/deps/abseil-cpp/absl/BUILD.bazel +62 -0
  18. package/deps/abseil-cpp/absl/CMakeLists.txt +45 -0
  19. package/deps/abseil-cpp/absl/abseil.podspec.gen.py +245 -0
  20. package/deps/abseil-cpp/absl/algorithm/BUILD.bazel +92 -0
  21. package/deps/abseil-cpp/absl/algorithm/CMakeLists.txt +72 -0
  22. package/deps/abseil-cpp/absl/algorithm/algorithm.h +64 -0
  23. package/deps/abseil-cpp/absl/algorithm/algorithm_test.cc +60 -0
  24. package/deps/abseil-cpp/absl/algorithm/container.h +1864 -0
  25. package/deps/abseil-cpp/absl/algorithm/container_test.cc +2232 -0
  26. package/deps/abseil-cpp/absl/base/BUILD.bazel +1036 -0
  27. package/deps/abseil-cpp/absl/base/CMakeLists.txt +881 -0
  28. package/deps/abseil-cpp/absl/base/attributes.h +1081 -0
  29. package/deps/abseil-cpp/absl/base/attributes_test.cc +43 -0
  30. package/deps/abseil-cpp/absl/base/bit_cast_test.cc +109 -0
  31. package/deps/abseil-cpp/absl/base/c_header_test.c +30 -0
  32. package/deps/abseil-cpp/absl/base/call_once.h +228 -0
  33. package/deps/abseil-cpp/absl/base/call_once_test.cc +107 -0
  34. package/deps/abseil-cpp/absl/base/casts.cc +61 -0
  35. package/deps/abseil-cpp/absl/base/casts.h +313 -0
  36. package/deps/abseil-cpp/absl/base/casts_test.cc +148 -0
  37. package/deps/abseil-cpp/absl/base/config.h +854 -0
  38. package/deps/abseil-cpp/absl/base/config_test.cc +60 -0
  39. package/deps/abseil-cpp/absl/base/const_init.h +76 -0
  40. package/deps/abseil-cpp/absl/base/dynamic_annotations.h +480 -0
  41. package/deps/abseil-cpp/absl/base/exception_safety_testing_test.cc +958 -0
  42. package/deps/abseil-cpp/absl/base/fast_type_id.h +73 -0
  43. package/deps/abseil-cpp/absl/base/fast_type_id_test.cc +130 -0
  44. package/deps/abseil-cpp/absl/base/internal/atomic_hook.h +200 -0
  45. package/deps/abseil-cpp/absl/base/internal/atomic_hook_test.cc +97 -0
  46. package/deps/abseil-cpp/absl/base/internal/atomic_hook_test_helper.cc +32 -0
  47. package/deps/abseil-cpp/absl/base/internal/atomic_hook_test_helper.h +34 -0
  48. package/deps/abseil-cpp/absl/base/internal/cmake_thread_test.cc +22 -0
  49. package/deps/abseil-cpp/absl/base/internal/cycleclock.cc +72 -0
  50. package/deps/abseil-cpp/absl/base/internal/cycleclock.h +144 -0
  51. package/deps/abseil-cpp/absl/base/internal/cycleclock_config.h +55 -0
  52. package/deps/abseil-cpp/absl/base/internal/direct_mmap.h +170 -0
  53. package/deps/abseil-cpp/absl/base/internal/dynamic_annotations.h +398 -0
  54. package/deps/abseil-cpp/absl/base/internal/endian.h +279 -0
  55. package/deps/abseil-cpp/absl/base/internal/endian_test.cc +263 -0
  56. package/deps/abseil-cpp/absl/base/internal/errno_saver.h +43 -0
  57. package/deps/abseil-cpp/absl/base/internal/errno_saver_test.cc +45 -0
  58. package/deps/abseil-cpp/absl/base/internal/exception_safety_testing.cc +79 -0
  59. package/deps/abseil-cpp/absl/base/internal/exception_safety_testing.h +1109 -0
  60. package/deps/abseil-cpp/absl/base/internal/exception_testing.h +42 -0
  61. package/deps/abseil-cpp/absl/base/internal/hide_ptr.h +51 -0
  62. package/deps/abseil-cpp/absl/base/internal/iterator_traits.h +75 -0
  63. package/deps/abseil-cpp/absl/base/internal/iterator_traits_test.cc +85 -0
  64. package/deps/abseil-cpp/absl/base/internal/iterator_traits_test_helper.h +97 -0
  65. package/deps/abseil-cpp/absl/base/internal/low_level_alloc.cc +661 -0
  66. package/deps/abseil-cpp/absl/base/internal/low_level_alloc.h +133 -0
  67. package/deps/abseil-cpp/absl/base/internal/low_level_alloc_test.cc +180 -0
  68. package/deps/abseil-cpp/absl/base/internal/low_level_scheduling.h +134 -0
  69. package/deps/abseil-cpp/absl/base/internal/nullability_traits.h +71 -0
  70. package/deps/abseil-cpp/absl/base/internal/nullability_traits_test.cc +98 -0
  71. package/deps/abseil-cpp/absl/base/internal/per_thread_tls.h +52 -0
  72. package/deps/abseil-cpp/absl/base/internal/poison.cc +85 -0
  73. package/deps/abseil-cpp/absl/base/internal/poison.h +59 -0
  74. package/deps/abseil-cpp/absl/base/internal/poison_test.cc +41 -0
  75. package/deps/abseil-cpp/absl/base/internal/pretty_function.h +33 -0
  76. package/deps/abseil-cpp/absl/base/internal/raw_logging.cc +279 -0
  77. package/deps/abseil-cpp/absl/base/internal/raw_logging.h +217 -0
  78. package/deps/abseil-cpp/absl/base/internal/scheduling_mode.h +58 -0
  79. package/deps/abseil-cpp/absl/base/internal/scoped_set_env.cc +81 -0
  80. package/deps/abseil-cpp/absl/base/internal/scoped_set_env.h +45 -0
  81. package/deps/abseil-cpp/absl/base/internal/scoped_set_env_test.cc +99 -0
  82. package/deps/abseil-cpp/absl/base/internal/spinlock.cc +225 -0
  83. package/deps/abseil-cpp/absl/base/internal/spinlock.h +310 -0
  84. package/deps/abseil-cpp/absl/base/internal/spinlock_akaros.inc +35 -0
  85. package/deps/abseil-cpp/absl/base/internal/spinlock_benchmark.cc +80 -0
  86. package/deps/abseil-cpp/absl/base/internal/spinlock_linux.inc +71 -0
  87. package/deps/abseil-cpp/absl/base/internal/spinlock_posix.inc +46 -0
  88. package/deps/abseil-cpp/absl/base/internal/spinlock_wait.cc +81 -0
  89. package/deps/abseil-cpp/absl/base/internal/spinlock_wait.h +95 -0
  90. package/deps/abseil-cpp/absl/base/internal/spinlock_win32.inc +40 -0
  91. package/deps/abseil-cpp/absl/base/internal/strerror.cc +88 -0
  92. package/deps/abseil-cpp/absl/base/internal/strerror.h +39 -0
  93. package/deps/abseil-cpp/absl/base/internal/strerror_benchmark.cc +29 -0
  94. package/deps/abseil-cpp/absl/base/internal/strerror_test.cc +89 -0
  95. package/deps/abseil-cpp/absl/base/internal/sysinfo.cc +494 -0
  96. package/deps/abseil-cpp/absl/base/internal/sysinfo.h +74 -0
  97. package/deps/abseil-cpp/absl/base/internal/sysinfo_test.cc +82 -0
  98. package/deps/abseil-cpp/absl/base/internal/thread_identity.cc +163 -0
  99. package/deps/abseil-cpp/absl/base/internal/thread_identity.h +273 -0
  100. package/deps/abseil-cpp/absl/base/internal/thread_identity_benchmark.cc +38 -0
  101. package/deps/abseil-cpp/absl/base/internal/thread_identity_test.cc +129 -0
  102. package/deps/abseil-cpp/absl/base/internal/throw_delegate.cc +203 -0
  103. package/deps/abseil-cpp/absl/base/internal/throw_delegate.h +75 -0
  104. package/deps/abseil-cpp/absl/base/internal/tracing.cc +39 -0
  105. package/deps/abseil-cpp/absl/base/internal/tracing.h +81 -0
  106. package/deps/abseil-cpp/absl/base/internal/tracing_strong_test.cc +117 -0
  107. package/deps/abseil-cpp/absl/base/internal/tracing_weak_test.cc +34 -0
  108. package/deps/abseil-cpp/absl/base/internal/tsan_mutex_interface.h +68 -0
  109. package/deps/abseil-cpp/absl/base/internal/unaligned_access.h +89 -0
  110. package/deps/abseil-cpp/absl/base/internal/unique_small_name_test.cc +77 -0
  111. package/deps/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +134 -0
  112. package/deps/abseil-cpp/absl/base/internal/unscaledcycleclock.h +113 -0
  113. package/deps/abseil-cpp/absl/base/internal/unscaledcycleclock_config.h +62 -0
  114. package/deps/abseil-cpp/absl/base/log_severity.cc +56 -0
  115. package/deps/abseil-cpp/absl/base/log_severity.h +185 -0
  116. package/deps/abseil-cpp/absl/base/log_severity_test.cc +251 -0
  117. package/deps/abseil-cpp/absl/base/macros.h +243 -0
  118. package/deps/abseil-cpp/absl/base/no_destructor.h +191 -0
  119. package/deps/abseil-cpp/absl/base/no_destructor_benchmark.cc +165 -0
  120. package/deps/abseil-cpp/absl/base/no_destructor_test.cc +205 -0
  121. package/deps/abseil-cpp/absl/base/nullability.h +317 -0
  122. package/deps/abseil-cpp/absl/base/nullability_default_nonnull_test.cc +44 -0
  123. package/deps/abseil-cpp/absl/base/nullability_test.cc +90 -0
  124. package/deps/abseil-cpp/absl/base/optimization.h +310 -0
  125. package/deps/abseil-cpp/absl/base/optimization_test.cc +141 -0
  126. package/deps/abseil-cpp/absl/base/options.h +158 -0
  127. package/deps/abseil-cpp/absl/base/policy_checks.h +115 -0
  128. package/deps/abseil-cpp/absl/base/port.h +25 -0
  129. package/deps/abseil-cpp/absl/base/prefetch.h +209 -0
  130. package/deps/abseil-cpp/absl/base/prefetch_test.cc +64 -0
  131. package/deps/abseil-cpp/absl/base/raw_logging_test.cc +98 -0
  132. package/deps/abseil-cpp/absl/base/spinlock_test_common.cc +302 -0
  133. package/deps/abseil-cpp/absl/base/thread_annotations.h +333 -0
  134. package/deps/abseil-cpp/absl/base/throw_delegate_test.cc +175 -0
  135. package/deps/abseil-cpp/absl/cleanup/BUILD.bazel +74 -0
  136. package/deps/abseil-cpp/absl/cleanup/CMakeLists.txt +55 -0
  137. package/deps/abseil-cpp/absl/cleanup/cleanup.h +142 -0
  138. package/deps/abseil-cpp/absl/cleanup/cleanup_test.cc +309 -0
  139. package/deps/abseil-cpp/absl/cleanup/internal/cleanup.h +99 -0
  140. package/deps/abseil-cpp/absl/container/BUILD.bazel +1394 -0
  141. package/deps/abseil-cpp/absl/container/CMakeLists.txt +1239 -0
  142. package/deps/abseil-cpp/absl/container/btree_benchmark.cc +806 -0
  143. package/deps/abseil-cpp/absl/container/btree_map.h +941 -0
  144. package/deps/abseil-cpp/absl/container/btree_set.h +872 -0
  145. package/deps/abseil-cpp/absl/container/btree_test.cc +3653 -0
  146. package/deps/abseil-cpp/absl/container/btree_test.h +166 -0
  147. package/deps/abseil-cpp/absl/container/chunked_queue.h +755 -0
  148. package/deps/abseil-cpp/absl/container/chunked_queue_benchmark.cc +386 -0
  149. package/deps/abseil-cpp/absl/container/chunked_queue_test.cc +768 -0
  150. package/deps/abseil-cpp/absl/container/fixed_array.h +547 -0
  151. package/deps/abseil-cpp/absl/container/fixed_array_benchmark.cc +67 -0
  152. package/deps/abseil-cpp/absl/container/fixed_array_exception_safety_test.cc +201 -0
  153. package/deps/abseil-cpp/absl/container/fixed_array_test.cc +874 -0
  154. package/deps/abseil-cpp/absl/container/flat_hash_map.h +702 -0
  155. package/deps/abseil-cpp/absl/container/flat_hash_map_test.cc +451 -0
  156. package/deps/abseil-cpp/absl/container/flat_hash_set.h +590 -0
  157. package/deps/abseil-cpp/absl/container/flat_hash_set_test.cc +401 -0
  158. package/deps/abseil-cpp/absl/container/hash_container_defaults.h +45 -0
  159. package/deps/abseil-cpp/absl/container/inlined_vector.h +1025 -0
  160. package/deps/abseil-cpp/absl/container/inlined_vector_benchmark.cc +829 -0
  161. package/deps/abseil-cpp/absl/container/inlined_vector_exception_safety_test.cc +508 -0
  162. package/deps/abseil-cpp/absl/container/inlined_vector_test.cc +2278 -0
  163. package/deps/abseil-cpp/absl/container/internal/btree.h +3149 -0
  164. package/deps/abseil-cpp/absl/container/internal/btree_container.h +876 -0
  165. package/deps/abseil-cpp/absl/container/internal/chunked_queue.h +173 -0
  166. package/deps/abseil-cpp/absl/container/internal/common.h +301 -0
  167. package/deps/abseil-cpp/absl/container/internal/common_policy_traits.h +151 -0
  168. package/deps/abseil-cpp/absl/container/internal/common_policy_traits_test.cc +157 -0
  169. package/deps/abseil-cpp/absl/container/internal/compressed_tuple.h +275 -0
  170. package/deps/abseil-cpp/absl/container/internal/compressed_tuple_test.cc +469 -0
  171. package/deps/abseil-cpp/absl/container/internal/container_memory.h +561 -0
  172. package/deps/abseil-cpp/absl/container/internal/container_memory_test.cc +359 -0
  173. package/deps/abseil-cpp/absl/container/internal/hash_function_defaults.h +281 -0
  174. package/deps/abseil-cpp/absl/container/internal/hash_function_defaults_test.cc +633 -0
  175. package/deps/abseil-cpp/absl/container/internal/hash_generator_testing.cc +54 -0
  176. package/deps/abseil-cpp/absl/container/internal/hash_generator_testing.h +172 -0
  177. package/deps/abseil-cpp/absl/container/internal/hash_policy_testing.h +173 -0
  178. package/deps/abseil-cpp/absl/container/internal/hash_policy_testing_test.cc +45 -0
  179. package/deps/abseil-cpp/absl/container/internal/hash_policy_traits.h +195 -0
  180. package/deps/abseil-cpp/absl/container/internal/hash_policy_traits_test.cc +149 -0
  181. package/deps/abseil-cpp/absl/container/internal/hashtable_control_bytes.h +527 -0
  182. package/deps/abseil-cpp/absl/container/internal/hashtable_control_bytes_test.cc +259 -0
  183. package/deps/abseil-cpp/absl/container/internal/hashtable_debug.h +102 -0
  184. package/deps/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +85 -0
  185. package/deps/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +316 -0
  186. package/deps/abseil-cpp/absl/container/internal/hashtablez_sampler.h +311 -0
  187. package/deps/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +31 -0
  188. package/deps/abseil-cpp/absl/container/internal/hashtablez_sampler_test.cc +534 -0
  189. package/deps/abseil-cpp/absl/container/internal/heterogeneous_lookup_testing.h +80 -0
  190. package/deps/abseil-cpp/absl/container/internal/inlined_vector.h +1094 -0
  191. package/deps/abseil-cpp/absl/container/internal/layout.h +828 -0
  192. package/deps/abseil-cpp/absl/container/internal/layout_benchmark.cc +295 -0
  193. package/deps/abseil-cpp/absl/container/internal/layout_test.cc +2034 -0
  194. package/deps/abseil-cpp/absl/container/internal/node_slot_policy.h +95 -0
  195. package/deps/abseil-cpp/absl/container/internal/node_slot_policy_test.cc +71 -0
  196. package/deps/abseil-cpp/absl/container/internal/raw_hash_map.h +382 -0
  197. package/deps/abseil-cpp/absl/container/internal/raw_hash_set.cc +2090 -0
  198. package/deps/abseil-cpp/absl/container/internal/raw_hash_set.h +3763 -0
  199. package/deps/abseil-cpp/absl/container/internal/raw_hash_set_allocator_test.cc +525 -0
  200. package/deps/abseil-cpp/absl/container/internal/raw_hash_set_benchmark.cc +696 -0
  201. package/deps/abseil-cpp/absl/container/internal/raw_hash_set_probe_benchmark.cc +583 -0
  202. package/deps/abseil-cpp/absl/container/internal/raw_hash_set_resize_impl.h +79 -0
  203. package/deps/abseil-cpp/absl/container/internal/raw_hash_set_resize_impl_test.cc +66 -0
  204. package/deps/abseil-cpp/absl/container/internal/raw_hash_set_test.cc +4184 -0
  205. package/deps/abseil-cpp/absl/container/internal/test_allocator.h +387 -0
  206. package/deps/abseil-cpp/absl/container/internal/test_instance_tracker.cc +29 -0
  207. package/deps/abseil-cpp/absl/container/internal/test_instance_tracker.h +274 -0
  208. package/deps/abseil-cpp/absl/container/internal/test_instance_tracker_test.cc +184 -0
  209. package/deps/abseil-cpp/absl/container/internal/tracked.h +83 -0
  210. package/deps/abseil-cpp/absl/container/internal/unordered_map_constructor_test.h +435 -0
  211. package/deps/abseil-cpp/absl/container/internal/unordered_map_lookup_test.h +112 -0
  212. package/deps/abseil-cpp/absl/container/internal/unordered_map_members_test.h +87 -0
  213. package/deps/abseil-cpp/absl/container/internal/unordered_map_modifiers_test.h +336 -0
  214. package/deps/abseil-cpp/absl/container/internal/unordered_map_test.cc +50 -0
  215. package/deps/abseil-cpp/absl/container/internal/unordered_set_constructor_test.h +437 -0
  216. package/deps/abseil-cpp/absl/container/internal/unordered_set_lookup_test.h +88 -0
  217. package/deps/abseil-cpp/absl/container/internal/unordered_set_members_test.h +86 -0
  218. package/deps/abseil-cpp/absl/container/internal/unordered_set_modifiers_test.h +215 -0
  219. package/deps/abseil-cpp/absl/container/internal/unordered_set_test.cc +41 -0
  220. package/deps/abseil-cpp/absl/container/linked_hash_map.h +666 -0
  221. package/deps/abseil-cpp/absl/container/linked_hash_map_benchmark.cc +140 -0
  222. package/deps/abseil-cpp/absl/container/linked_hash_map_test.cc +987 -0
  223. package/deps/abseil-cpp/absl/container/linked_hash_set.h +527 -0
  224. package/deps/abseil-cpp/absl/container/linked_hash_set_benchmark.cc +84 -0
  225. package/deps/abseil-cpp/absl/container/linked_hash_set_test.cc +947 -0
  226. package/deps/abseil-cpp/absl/container/node_hash_map.h +698 -0
  227. package/deps/abseil-cpp/absl/container/node_hash_map_test.cc +348 -0
  228. package/deps/abseil-cpp/absl/container/node_hash_set.h +589 -0
  229. package/deps/abseil-cpp/absl/container/node_hash_set_test.cc +188 -0
  230. package/deps/abseil-cpp/absl/container/sample_element_size_test.cc +118 -0
  231. package/deps/abseil-cpp/absl/copts/AbseilConfigureCopts.cmake +106 -0
  232. package/deps/abseil-cpp/absl/copts/GENERATED_AbseilCopts.cmake +303 -0
  233. package/deps/abseil-cpp/absl/copts/GENERATED_copts.bzl +304 -0
  234. package/deps/abseil-cpp/absl/copts/configure_copts.bzl +39 -0
  235. package/deps/abseil-cpp/absl/copts/copts.py +205 -0
  236. package/deps/abseil-cpp/absl/copts/generate_copts.py +109 -0
  237. package/deps/abseil-cpp/absl/crc/BUILD.bazel +228 -0
  238. package/deps/abseil-cpp/absl/crc/CMakeLists.txt +177 -0
  239. package/deps/abseil-cpp/absl/crc/crc32c.cc +95 -0
  240. package/deps/abseil-cpp/absl/crc/crc32c.h +192 -0
  241. package/deps/abseil-cpp/absl/crc/crc32c_benchmark.cc +196 -0
  242. package/deps/abseil-cpp/absl/crc/crc32c_test.cc +257 -0
  243. package/deps/abseil-cpp/absl/crc/internal/cpu_detect.cc +359 -0
  244. package/deps/abseil-cpp/absl/crc/internal/cpu_detect.h +69 -0
  245. package/deps/abseil-cpp/absl/crc/internal/crc.cc +435 -0
  246. package/deps/abseil-cpp/absl/crc/internal/crc.h +83 -0
  247. package/deps/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +278 -0
  248. package/deps/abseil-cpp/absl/crc/internal/crc32c.h +39 -0
  249. package/deps/abseil-cpp/absl/crc/internal/crc32c_inline.h +72 -0
  250. package/deps/abseil-cpp/absl/crc/internal/crc_cord_state.cc +131 -0
  251. package/deps/abseil-cpp/absl/crc/internal/crc_cord_state.h +159 -0
  252. package/deps/abseil-cpp/absl/crc/internal/crc_cord_state_test.cc +124 -0
  253. package/deps/abseil-cpp/absl/crc/internal/crc_internal.h +161 -0
  254. package/deps/abseil-cpp/absl/crc/internal/crc_memcpy.h +122 -0
  255. package/deps/abseil-cpp/absl/crc/internal/crc_memcpy_fallback.cc +78 -0
  256. package/deps/abseil-cpp/absl/crc/internal/crc_memcpy_test.cc +177 -0
  257. package/deps/abseil-cpp/absl/crc/internal/crc_memcpy_x86_arm_combined.cc +459 -0
  258. package/deps/abseil-cpp/absl/crc/internal/crc_non_temporal_memcpy.cc +93 -0
  259. package/deps/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +762 -0
  260. package/deps/abseil-cpp/absl/crc/internal/gen_crc32c_consts.py +90 -0
  261. package/deps/abseil-cpp/absl/crc/internal/non_temporal_arm_intrinsics.h +81 -0
  262. package/deps/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +195 -0
  263. package/deps/abseil-cpp/absl/crc/internal/non_temporal_memcpy_test.cc +90 -0
  264. package/deps/abseil-cpp/absl/debugging/BUILD.bazel +483 -0
  265. package/deps/abseil-cpp/absl/debugging/CMakeLists.txt +448 -0
  266. package/deps/abseil-cpp/absl/debugging/failure_signal_handler.cc +434 -0
  267. package/deps/abseil-cpp/absl/debugging/failure_signal_handler.h +121 -0
  268. package/deps/abseil-cpp/absl/debugging/failure_signal_handler_test.cc +166 -0
  269. package/deps/abseil-cpp/absl/debugging/internal/address_is_readable.cc +98 -0
  270. package/deps/abseil-cpp/absl/debugging/internal/address_is_readable.h +32 -0
  271. package/deps/abseil-cpp/absl/debugging/internal/addresses.h +57 -0
  272. package/deps/abseil-cpp/absl/debugging/internal/borrowed_fixup_buffer.cc +118 -0
  273. package/deps/abseil-cpp/absl/debugging/internal/borrowed_fixup_buffer.h +71 -0
  274. package/deps/abseil-cpp/absl/debugging/internal/borrowed_fixup_buffer_test.cc +97 -0
  275. package/deps/abseil-cpp/absl/debugging/internal/bounded_utf8_length_sequence.h +126 -0
  276. package/deps/abseil-cpp/absl/debugging/internal/bounded_utf8_length_sequence_test.cc +126 -0
  277. package/deps/abseil-cpp/absl/debugging/internal/decode_rust_punycode.cc +258 -0
  278. package/deps/abseil-cpp/absl/debugging/internal/decode_rust_punycode.h +55 -0
  279. package/deps/abseil-cpp/absl/debugging/internal/decode_rust_punycode_test.cc +606 -0
  280. package/deps/abseil-cpp/absl/debugging/internal/demangle.cc +2958 -0
  281. package/deps/abseil-cpp/absl/debugging/internal/demangle.h +76 -0
  282. package/deps/abseil-cpp/absl/debugging/internal/demangle_rust.cc +925 -0
  283. package/deps/abseil-cpp/absl/debugging/internal/demangle_rust.h +42 -0
  284. package/deps/abseil-cpp/absl/debugging/internal/demangle_rust_test.cc +584 -0
  285. package/deps/abseil-cpp/absl/debugging/internal/demangle_test.cc +2050 -0
  286. package/deps/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +413 -0
  287. package/deps/abseil-cpp/absl/debugging/internal/elf_mem_image.h +141 -0
  288. package/deps/abseil-cpp/absl/debugging/internal/examine_stack.cc +334 -0
  289. package/deps/abseil-cpp/absl/debugging/internal/examine_stack.h +70 -0
  290. package/deps/abseil-cpp/absl/debugging/internal/stack_consumption.cc +206 -0
  291. package/deps/abseil-cpp/absl/debugging/internal/stack_consumption.h +50 -0
  292. package/deps/abseil-cpp/absl/debugging/internal/stack_consumption_test.cc +50 -0
  293. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +288 -0
  294. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +148 -0
  295. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_config.h +96 -0
  296. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_emscripten-inl.inc +112 -0
  297. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +114 -0
  298. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +270 -0
  299. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +204 -0
  300. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +25 -0
  301. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +81 -0
  302. package/deps/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +410 -0
  303. package/deps/abseil-cpp/absl/debugging/internal/symbolize.h +153 -0
  304. package/deps/abseil-cpp/absl/debugging/internal/utf8_for_code_point.cc +70 -0
  305. package/deps/abseil-cpp/absl/debugging/internal/utf8_for_code_point.h +47 -0
  306. package/deps/abseil-cpp/absl/debugging/internal/utf8_for_code_point_test.cc +175 -0
  307. package/deps/abseil-cpp/absl/debugging/internal/vdso_support.cc +209 -0
  308. package/deps/abseil-cpp/absl/debugging/internal/vdso_support.h +158 -0
  309. package/deps/abseil-cpp/absl/debugging/leak_check.cc +73 -0
  310. package/deps/abseil-cpp/absl/debugging/leak_check.h +150 -0
  311. package/deps/abseil-cpp/absl/debugging/leak_check_fail_test.cc +41 -0
  312. package/deps/abseil-cpp/absl/debugging/leak_check_test.cc +41 -0
  313. package/deps/abseil-cpp/absl/debugging/stacktrace.cc +244 -0
  314. package/deps/abseil-cpp/absl/debugging/stacktrace.h +302 -0
  315. package/deps/abseil-cpp/absl/debugging/stacktrace_benchmark.cc +78 -0
  316. package/deps/abseil-cpp/absl/debugging/stacktrace_test.cc +505 -0
  317. package/deps/abseil-cpp/absl/debugging/symbolize.cc +44 -0
  318. package/deps/abseil-cpp/absl/debugging/symbolize.h +99 -0
  319. package/deps/abseil-cpp/absl/debugging/symbolize_darwin.inc +102 -0
  320. package/deps/abseil-cpp/absl/debugging/symbolize_elf.inc +1756 -0
  321. package/deps/abseil-cpp/absl/debugging/symbolize_emscripten.inc +63 -0
  322. package/deps/abseil-cpp/absl/debugging/symbolize_test.cc +619 -0
  323. package/deps/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +40 -0
  324. package/deps/abseil-cpp/absl/debugging/symbolize_win32.inc +99 -0
  325. package/deps/abseil-cpp/absl/extend/CMakeLists.txt +140 -0
  326. package/deps/abseil-cpp/absl/extend/internal/BUILD.bazel +127 -0
  327. package/deps/abseil-cpp/absl/extend/internal/aggregate.h +1687 -0
  328. package/deps/abseil-cpp/absl/extend/internal/aggregate_test.cc +867 -0
  329. package/deps/abseil-cpp/absl/extend/internal/dependencies.h +83 -0
  330. package/deps/abseil-cpp/absl/extend/internal/dependencies_test.cc +117 -0
  331. package/deps/abseil-cpp/absl/extend/internal/is_tuple_hashable.h +45 -0
  332. package/deps/abseil-cpp/absl/extend/internal/num_bases.h +87 -0
  333. package/deps/abseil-cpp/absl/extend/internal/num_bases_test.cc +91 -0
  334. package/deps/abseil-cpp/absl/extend/internal/num_initializers.h +113 -0
  335. package/deps/abseil-cpp/absl/extend/internal/num_initializers_test.cc +250 -0
  336. package/deps/abseil-cpp/absl/extend/internal/reflection.cc +112 -0
  337. package/deps/abseil-cpp/absl/extend/internal/reflection.h +75 -0
  338. package/deps/abseil-cpp/absl/extend/internal/tuple.h +51 -0
  339. package/deps/abseil-cpp/absl/flags/BUILD.bazel +618 -0
  340. package/deps/abseil-cpp/absl/flags/CMakeLists.txt +482 -0
  341. package/deps/abseil-cpp/absl/flags/commandlineflag.cc +35 -0
  342. package/deps/abseil-cpp/absl/flags/commandlineflag.h +219 -0
  343. package/deps/abseil-cpp/absl/flags/commandlineflag_test.cc +236 -0
  344. package/deps/abseil-cpp/absl/flags/config.h +68 -0
  345. package/deps/abseil-cpp/absl/flags/config_test.cc +61 -0
  346. package/deps/abseil-cpp/absl/flags/declare.h +77 -0
  347. package/deps/abseil-cpp/absl/flags/flag.h +307 -0
  348. package/deps/abseil-cpp/absl/flags/flag_benchmark.cc +251 -0
  349. package/deps/abseil-cpp/absl/flags/flag_benchmark.lds +13 -0
  350. package/deps/abseil-cpp/absl/flags/flag_test.cc +1381 -0
  351. package/deps/abseil-cpp/absl/flags/flag_test_defs.cc +24 -0
  352. package/deps/abseil-cpp/absl/flags/internal/commandlineflag.cc +26 -0
  353. package/deps/abseil-cpp/absl/flags/internal/commandlineflag.h +68 -0
  354. package/deps/abseil-cpp/absl/flags/internal/flag.cc +712 -0
  355. package/deps/abseil-cpp/absl/flags/internal/flag.h +969 -0
  356. package/deps/abseil-cpp/absl/flags/internal/parse.h +70 -0
  357. package/deps/abseil-cpp/absl/flags/internal/path_util.h +62 -0
  358. package/deps/abseil-cpp/absl/flags/internal/path_util_test.cc +46 -0
  359. package/deps/abseil-cpp/absl/flags/internal/private_handle_accessor.cc +69 -0
  360. package/deps/abseil-cpp/absl/flags/internal/private_handle_accessor.h +64 -0
  361. package/deps/abseil-cpp/absl/flags/internal/program_name.cc +61 -0
  362. package/deps/abseil-cpp/absl/flags/internal/program_name.h +50 -0
  363. package/deps/abseil-cpp/absl/flags/internal/program_name_test.cc +61 -0
  364. package/deps/abseil-cpp/absl/flags/internal/registry.h +98 -0
  365. package/deps/abseil-cpp/absl/flags/internal/sequence_lock.h +187 -0
  366. package/deps/abseil-cpp/absl/flags/internal/sequence_lock_test.cc +169 -0
  367. package/deps/abseil-cpp/absl/flags/internal/usage.cc +558 -0
  368. package/deps/abseil-cpp/absl/flags/internal/usage.h +106 -0
  369. package/deps/abseil-cpp/absl/flags/internal/usage_test.cc +550 -0
  370. package/deps/abseil-cpp/absl/flags/marshalling.cc +276 -0
  371. package/deps/abseil-cpp/absl/flags/marshalling.h +361 -0
  372. package/deps/abseil-cpp/absl/flags/marshalling_test.cc +1220 -0
  373. package/deps/abseil-cpp/absl/flags/parse.cc +952 -0
  374. package/deps/abseil-cpp/absl/flags/parse.h +130 -0
  375. package/deps/abseil-cpp/absl/flags/parse_test.cc +1094 -0
  376. package/deps/abseil-cpp/absl/flags/reflection.cc +368 -0
  377. package/deps/abseil-cpp/absl/flags/reflection.h +90 -0
  378. package/deps/abseil-cpp/absl/flags/reflection_test.cc +268 -0
  379. package/deps/abseil-cpp/absl/flags/usage.cc +66 -0
  380. package/deps/abseil-cpp/absl/flags/usage.h +43 -0
  381. package/deps/abseil-cpp/absl/flags/usage_config.cc +170 -0
  382. package/deps/abseil-cpp/absl/flags/usage_config.h +135 -0
  383. package/deps/abseil-cpp/absl/flags/usage_config_test.cc +205 -0
  384. package/deps/abseil-cpp/absl/functional/BUILD.bazel +173 -0
  385. package/deps/abseil-cpp/absl/functional/CMakeLists.txt +140 -0
  386. package/deps/abseil-cpp/absl/functional/any_invocable.h +336 -0
  387. package/deps/abseil-cpp/absl/functional/any_invocable_test.cc +1687 -0
  388. package/deps/abseil-cpp/absl/functional/bind_front.h +200 -0
  389. package/deps/abseil-cpp/absl/functional/bind_front_test.cc +227 -0
  390. package/deps/abseil-cpp/absl/functional/function_ref.h +249 -0
  391. package/deps/abseil-cpp/absl/functional/function_ref_test.cc +416 -0
  392. package/deps/abseil-cpp/absl/functional/function_type_benchmark.cc +176 -0
  393. package/deps/abseil-cpp/absl/functional/internal/any_invocable.h +787 -0
  394. package/deps/abseil-cpp/absl/functional/internal/front_binder.h +93 -0
  395. package/deps/abseil-cpp/absl/functional/internal/function_ref.h +151 -0
  396. package/deps/abseil-cpp/absl/functional/overload.h +72 -0
  397. package/deps/abseil-cpp/absl/functional/overload_test.cc +207 -0
  398. package/deps/abseil-cpp/absl/hash/BUILD.bazel +220 -0
  399. package/deps/abseil-cpp/absl/hash/CMakeLists.txt +179 -0
  400. package/deps/abseil-cpp/absl/hash/hash.h +466 -0
  401. package/deps/abseil-cpp/absl/hash/hash_benchmark.cc +398 -0
  402. package/deps/abseil-cpp/absl/hash/hash_instantiated_test.cc +224 -0
  403. package/deps/abseil-cpp/absl/hash/hash_test.cc +1320 -0
  404. package/deps/abseil-cpp/absl/hash/hash_testing.h +380 -0
  405. package/deps/abseil-cpp/absl/hash/internal/city.cc +337 -0
  406. package/deps/abseil-cpp/absl/hash/internal/city.h +78 -0
  407. package/deps/abseil-cpp/absl/hash/internal/city_test.cc +597 -0
  408. package/deps/abseil-cpp/absl/hash/internal/hash.cc +430 -0
  409. package/deps/abseil-cpp/absl/hash/internal/hash.h +1563 -0
  410. package/deps/abseil-cpp/absl/hash/internal/hash_test.h +87 -0
  411. package/deps/abseil-cpp/absl/hash/internal/low_level_hash_test.cc +509 -0
  412. package/deps/abseil-cpp/absl/hash/internal/print_hash_of.cc +23 -0
  413. package/deps/abseil-cpp/absl/hash/internal/spy_hash_state.h +286 -0
  414. package/deps/abseil-cpp/absl/hash/internal/weakly_mixed_integer.h +38 -0
  415. package/deps/abseil-cpp/absl/log/BUILD.bazel +686 -0
  416. package/deps/abseil-cpp/absl/log/CMakeLists.txt +1239 -0
  417. package/deps/abseil-cpp/absl/log/absl_check.h +117 -0
  418. package/deps/abseil-cpp/absl/log/absl_check_test.cc +58 -0
  419. package/deps/abseil-cpp/absl/log/absl_log.h +115 -0
  420. package/deps/abseil-cpp/absl/log/absl_log_basic_test.cc +22 -0
  421. package/deps/abseil-cpp/absl/log/absl_vlog_is_on.h +95 -0
  422. package/deps/abseil-cpp/absl/log/check.h +210 -0
  423. package/deps/abseil-cpp/absl/log/check_test.cc +58 -0
  424. package/deps/abseil-cpp/absl/log/check_test_impl.inc +1035 -0
  425. package/deps/abseil-cpp/absl/log/die_if_null.cc +34 -0
  426. package/deps/abseil-cpp/absl/log/die_if_null.h +97 -0
  427. package/deps/abseil-cpp/absl/log/die_if_null_test.cc +107 -0
  428. package/deps/abseil-cpp/absl/log/flags.cc +143 -0
  429. package/deps/abseil-cpp/absl/log/flags.h +43 -0
  430. package/deps/abseil-cpp/absl/log/flags_test.cc +195 -0
  431. package/deps/abseil-cpp/absl/log/globals.cc +178 -0
  432. package/deps/abseil-cpp/absl/log/globals.h +230 -0
  433. package/deps/abseil-cpp/absl/log/globals_test.cc +156 -0
  434. package/deps/abseil-cpp/absl/log/initialize.cc +38 -0
  435. package/deps/abseil-cpp/absl/log/initialize.h +45 -0
  436. package/deps/abseil-cpp/absl/log/internal/BUILD.bazel +581 -0
  437. package/deps/abseil-cpp/absl/log/internal/append_truncated.h +75 -0
  438. package/deps/abseil-cpp/absl/log/internal/check_impl.h +151 -0
  439. package/deps/abseil-cpp/absl/log/internal/check_op.cc +147 -0
  440. package/deps/abseil-cpp/absl/log/internal/check_op.h +565 -0
  441. package/deps/abseil-cpp/absl/log/internal/conditions.cc +85 -0
  442. package/deps/abseil-cpp/absl/log/internal/conditions.h +247 -0
  443. package/deps/abseil-cpp/absl/log/internal/config.h +45 -0
  444. package/deps/abseil-cpp/absl/log/internal/container.h +312 -0
  445. package/deps/abseil-cpp/absl/log/internal/container_test.cc +254 -0
  446. package/deps/abseil-cpp/absl/log/internal/flags.h +59 -0
  447. package/deps/abseil-cpp/absl/log/internal/fnmatch.cc +73 -0
  448. package/deps/abseil-cpp/absl/log/internal/fnmatch.h +35 -0
  449. package/deps/abseil-cpp/absl/log/internal/fnmatch_benchmark.cc +29 -0
  450. package/deps/abseil-cpp/absl/log/internal/fnmatch_test.cc +60 -0
  451. package/deps/abseil-cpp/absl/log/internal/globals.cc +145 -0
  452. package/deps/abseil-cpp/absl/log/internal/globals.h +101 -0
  453. package/deps/abseil-cpp/absl/log/internal/log_format.cc +205 -0
  454. package/deps/abseil-cpp/absl/log/internal/log_format.h +78 -0
  455. package/deps/abseil-cpp/absl/log/internal/log_impl.h +280 -0
  456. package/deps/abseil-cpp/absl/log/internal/log_message.cc +787 -0
  457. package/deps/abseil-cpp/absl/log/internal/log_message.h +455 -0
  458. package/deps/abseil-cpp/absl/log/internal/log_sink_set.cc +296 -0
  459. package/deps/abseil-cpp/absl/log/internal/log_sink_set.h +54 -0
  460. package/deps/abseil-cpp/absl/log/internal/nullguard.cc +35 -0
  461. package/deps/abseil-cpp/absl/log/internal/nullguard.h +88 -0
  462. package/deps/abseil-cpp/absl/log/internal/nullstream.h +128 -0
  463. package/deps/abseil-cpp/absl/log/internal/proto.cc +218 -0
  464. package/deps/abseil-cpp/absl/log/internal/proto.h +298 -0
  465. package/deps/abseil-cpp/absl/log/internal/stderr_log_sink_test.cc +105 -0
  466. package/deps/abseil-cpp/absl/log/internal/strip.h +99 -0
  467. package/deps/abseil-cpp/absl/log/internal/structured.h +160 -0
  468. package/deps/abseil-cpp/absl/log/internal/structured_proto.cc +115 -0
  469. package/deps/abseil-cpp/absl/log/internal/structured_proto.h +107 -0
  470. package/deps/abseil-cpp/absl/log/internal/structured_proto_test.cc +120 -0
  471. package/deps/abseil-cpp/absl/log/internal/test_actions.cc +75 -0
  472. package/deps/abseil-cpp/absl/log/internal/test_actions.h +90 -0
  473. package/deps/abseil-cpp/absl/log/internal/test_helpers.cc +82 -0
  474. package/deps/abseil-cpp/absl/log/internal/test_helpers.h +71 -0
  475. package/deps/abseil-cpp/absl/log/internal/test_matchers.cc +216 -0
  476. package/deps/abseil-cpp/absl/log/internal/test_matchers.h +94 -0
  477. package/deps/abseil-cpp/absl/log/internal/vlog_config.cc +347 -0
  478. package/deps/abseil-cpp/absl/log/internal/vlog_config.h +164 -0
  479. package/deps/abseil-cpp/absl/log/internal/vlog_config_benchmark.cc +187 -0
  480. package/deps/abseil-cpp/absl/log/internal/voidify.h +50 -0
  481. package/deps/abseil-cpp/absl/log/log.h +378 -0
  482. package/deps/abseil-cpp/absl/log/log_basic_test.cc +22 -0
  483. package/deps/abseil-cpp/absl/log/log_basic_test_impl.inc +654 -0
  484. package/deps/abseil-cpp/absl/log/log_benchmark.cc +164 -0
  485. package/deps/abseil-cpp/absl/log/log_entry.cc +263 -0
  486. package/deps/abseil-cpp/absl/log/log_entry.h +223 -0
  487. package/deps/abseil-cpp/absl/log/log_entry_test.cc +468 -0
  488. package/deps/abseil-cpp/absl/log/log_format_test.cc +2261 -0
  489. package/deps/abseil-cpp/absl/log/log_macro_hygiene_test.cc +187 -0
  490. package/deps/abseil-cpp/absl/log/log_modifier_methods_test.cc +244 -0
  491. package/deps/abseil-cpp/absl/log/log_sink.cc +23 -0
  492. package/deps/abseil-cpp/absl/log/log_sink.h +71 -0
  493. package/deps/abseil-cpp/absl/log/log_sink_registry.h +64 -0
  494. package/deps/abseil-cpp/absl/log/log_sink_test.cc +418 -0
  495. package/deps/abseil-cpp/absl/log/log_streamer.h +181 -0
  496. package/deps/abseil-cpp/absl/log/log_streamer_test.cc +451 -0
  497. package/deps/abseil-cpp/absl/log/scoped_mock_log.cc +86 -0
  498. package/deps/abseil-cpp/absl/log/scoped_mock_log.h +203 -0
  499. package/deps/abseil-cpp/absl/log/scoped_mock_log_test.cc +295 -0
  500. package/deps/abseil-cpp/absl/log/stripping_test.cc +502 -0
  501. package/deps/abseil-cpp/absl/log/structured.h +75 -0
  502. package/deps/abseil-cpp/absl/log/structured_test.cc +64 -0
  503. package/deps/abseil-cpp/absl/log/vlog_is_on.h +74 -0
  504. package/deps/abseil-cpp/absl/log/vlog_is_on_test.cc +233 -0
  505. package/deps/abseil-cpp/absl/memory/BUILD.bazel +62 -0
  506. package/deps/abseil-cpp/absl/memory/CMakeLists.txt +41 -0
  507. package/deps/abseil-cpp/absl/memory/memory.h +278 -0
  508. package/deps/abseil-cpp/absl/memory/memory_test.cc +222 -0
  509. package/deps/abseil-cpp/absl/meta/BUILD.bazel +112 -0
  510. package/deps/abseil-cpp/absl/meta/CMakeLists.txt +100 -0
  511. package/deps/abseil-cpp/absl/meta/internal/constexpr_testing.h +73 -0
  512. package/deps/abseil-cpp/absl/meta/internal/constexpr_testing_test.cc +40 -0
  513. package/deps/abseil-cpp/absl/meta/internal/requires.h +67 -0
  514. package/deps/abseil-cpp/absl/meta/internal/requires_test.cc +66 -0
  515. package/deps/abseil-cpp/absl/meta/type_traits.h +582 -0
  516. package/deps/abseil-cpp/absl/meta/type_traits_test.cc +378 -0
  517. package/deps/abseil-cpp/absl/numeric/BUILD.bazel +145 -0
  518. package/deps/abseil-cpp/absl/numeric/CMakeLists.txt +104 -0
  519. package/deps/abseil-cpp/absl/numeric/bits.h +262 -0
  520. package/deps/abseil-cpp/absl/numeric/bits_benchmark.cc +73 -0
  521. package/deps/abseil-cpp/absl/numeric/bits_test.cc +724 -0
  522. package/deps/abseil-cpp/absl/numeric/int128.cc +344 -0
  523. package/deps/abseil-cpp/absl/numeric/int128.h +1224 -0
  524. package/deps/abseil-cpp/absl/numeric/int128_benchmark.cc +281 -0
  525. package/deps/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +303 -0
  526. package/deps/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +347 -0
  527. package/deps/abseil-cpp/absl/numeric/int128_stream_test.cc +1400 -0
  528. package/deps/abseil-cpp/absl/numeric/int128_test.cc +1407 -0
  529. package/deps/abseil-cpp/absl/numeric/internal/bits.h +394 -0
  530. package/deps/abseil-cpp/absl/numeric/internal/representation.h +55 -0
  531. package/deps/abseil-cpp/absl/profiling/BUILD.bazel +188 -0
  532. package/deps/abseil-cpp/absl/profiling/CMakeLists.txt +132 -0
  533. package/deps/abseil-cpp/absl/profiling/hashtable.cc +135 -0
  534. package/deps/abseil-cpp/absl/profiling/hashtable.h +40 -0
  535. package/deps/abseil-cpp/absl/profiling/internal/exponential_biased.cc +93 -0
  536. package/deps/abseil-cpp/absl/profiling/internal/exponential_biased.h +130 -0
  537. package/deps/abseil-cpp/absl/profiling/internal/exponential_biased_test.cc +203 -0
  538. package/deps/abseil-cpp/absl/profiling/internal/periodic_sampler.cc +53 -0
  539. package/deps/abseil-cpp/absl/profiling/internal/periodic_sampler.h +211 -0
  540. package/deps/abseil-cpp/absl/profiling/internal/periodic_sampler_benchmark.cc +79 -0
  541. package/deps/abseil-cpp/absl/profiling/internal/periodic_sampler_test.cc +177 -0
  542. package/deps/abseil-cpp/absl/profiling/internal/profile_builder.cc +463 -0
  543. package/deps/abseil-cpp/absl/profiling/internal/profile_builder.h +161 -0
  544. package/deps/abseil-cpp/absl/profiling/internal/sample_recorder.h +253 -0
  545. package/deps/abseil-cpp/absl/profiling/internal/sample_recorder_test.cc +188 -0
  546. package/deps/abseil-cpp/absl/random/BUILD.bazel +550 -0
  547. package/deps/abseil-cpp/absl/random/CMakeLists.txt +1250 -0
  548. package/deps/abseil-cpp/absl/random/benchmarks.cc +376 -0
  549. package/deps/abseil-cpp/absl/random/bernoulli_distribution.h +202 -0
  550. package/deps/abseil-cpp/absl/random/bernoulli_distribution_test.cc +217 -0
  551. package/deps/abseil-cpp/absl/random/beta_distribution.h +429 -0
  552. package/deps/abseil-cpp/absl/random/beta_distribution_test.cc +615 -0
  553. package/deps/abseil-cpp/absl/random/bit_gen_ref.h +187 -0
  554. package/deps/abseil-cpp/absl/random/bit_gen_ref_test.cc +107 -0
  555. package/deps/abseil-cpp/absl/random/discrete_distribution.cc +108 -0
  556. package/deps/abseil-cpp/absl/random/discrete_distribution.h +249 -0
  557. package/deps/abseil-cpp/absl/random/discrete_distribution_test.cc +251 -0
  558. package/deps/abseil-cpp/absl/random/distributions.h +450 -0
  559. package/deps/abseil-cpp/absl/random/distributions_test.cc +516 -0
  560. package/deps/abseil-cpp/absl/random/examples_test.cc +98 -0
  561. package/deps/abseil-cpp/absl/random/exponential_distribution.h +166 -0
  562. package/deps/abseil-cpp/absl/random/exponential_distribution_test.cc +426 -0
  563. package/deps/abseil-cpp/absl/random/gaussian_distribution.cc +104 -0
  564. package/deps/abseil-cpp/absl/random/gaussian_distribution.h +276 -0
  565. package/deps/abseil-cpp/absl/random/gaussian_distribution_test.cc +561 -0
  566. package/deps/abseil-cpp/absl/random/generators_test.cc +185 -0
  567. package/deps/abseil-cpp/absl/random/internal/BUILD.bazel +863 -0
  568. package/deps/abseil-cpp/absl/random/internal/chi_square.cc +230 -0
  569. package/deps/abseil-cpp/absl/random/internal/chi_square.h +89 -0
  570. package/deps/abseil-cpp/absl/random/internal/chi_square_test.cc +364 -0
  571. package/deps/abseil-cpp/absl/random/internal/distribution_caller.h +96 -0
  572. package/deps/abseil-cpp/absl/random/internal/distribution_test_util.cc +418 -0
  573. package/deps/abseil-cpp/absl/random/internal/distribution_test_util.h +113 -0
  574. package/deps/abseil-cpp/absl/random/internal/distribution_test_util_test.cc +193 -0
  575. package/deps/abseil-cpp/absl/random/internal/entropy_pool.cc +185 -0
  576. package/deps/abseil-cpp/absl/random/internal/entropy_pool.h +35 -0
  577. package/deps/abseil-cpp/absl/random/internal/entropy_pool_test.cc +119 -0
  578. package/deps/abseil-cpp/absl/random/internal/explicit_seed_seq.h +92 -0
  579. package/deps/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc +241 -0
  580. package/deps/abseil-cpp/absl/random/internal/fast_uniform_bits.h +271 -0
  581. package/deps/abseil-cpp/absl/random/internal/fast_uniform_bits_test.cc +336 -0
  582. package/deps/abseil-cpp/absl/random/internal/fastmath.h +57 -0
  583. package/deps/abseil-cpp/absl/random/internal/fastmath_test.cc +95 -0
  584. package/deps/abseil-cpp/absl/random/internal/gaussian_distribution_gentables.cc +142 -0
  585. package/deps/abseil-cpp/absl/random/internal/generate_real.h +144 -0
  586. package/deps/abseil-cpp/absl/random/internal/generate_real_test.cc +496 -0
  587. package/deps/abseil-cpp/absl/random/internal/iostream_state_saver.h +248 -0
  588. package/deps/abseil-cpp/absl/random/internal/iostream_state_saver_test.cc +373 -0
  589. package/deps/abseil-cpp/absl/random/internal/mock_helpers.h +160 -0
  590. package/deps/abseil-cpp/absl/random/internal/mock_overload_set.h +122 -0
  591. package/deps/abseil-cpp/absl/random/internal/mock_validators.h +98 -0
  592. package/deps/abseil-cpp/absl/random/internal/nanobenchmark.cc +804 -0
  593. package/deps/abseil-cpp/absl/random/internal/nanobenchmark.h +172 -0
  594. package/deps/abseil-cpp/absl/random/internal/nanobenchmark_test.cc +79 -0
  595. package/deps/abseil-cpp/absl/random/internal/nonsecure_base.h +160 -0
  596. package/deps/abseil-cpp/absl/random/internal/nonsecure_base_test.cc +267 -0
  597. package/deps/abseil-cpp/absl/random/internal/pcg_engine.h +287 -0
  598. package/deps/abseil-cpp/absl/random/internal/pcg_engine_test.cc +638 -0
  599. package/deps/abseil-cpp/absl/random/internal/platform.h +158 -0
  600. package/deps/abseil-cpp/absl/random/internal/randen.cc +91 -0
  601. package/deps/abseil-cpp/absl/random/internal/randen.h +96 -0
  602. package/deps/abseil-cpp/absl/random/internal/randen_benchmarks.cc +177 -0
  603. package/deps/abseil-cpp/absl/random/internal/randen_detect.cc +280 -0
  604. package/deps/abseil-cpp/absl/random/internal/randen_detect.h +33 -0
  605. package/deps/abseil-cpp/absl/random/internal/randen_engine.h +265 -0
  606. package/deps/abseil-cpp/absl/random/internal/randen_engine_test.cc +654 -0
  607. package/deps/abseil-cpp/absl/random/internal/randen_hwaes.cc +526 -0
  608. package/deps/abseil-cpp/absl/random/internal/randen_hwaes.h +50 -0
  609. package/deps/abseil-cpp/absl/random/internal/randen_hwaes_test.cc +99 -0
  610. package/deps/abseil-cpp/absl/random/internal/randen_round_keys.cc +462 -0
  611. package/deps/abseil-cpp/absl/random/internal/randen_slow.cc +471 -0
  612. package/deps/abseil-cpp/absl/random/internal/randen_slow.h +40 -0
  613. package/deps/abseil-cpp/absl/random/internal/randen_slow_test.cc +61 -0
  614. package/deps/abseil-cpp/absl/random/internal/randen_test.cc +75 -0
  615. package/deps/abseil-cpp/absl/random/internal/randen_traits.h +88 -0
  616. package/deps/abseil-cpp/absl/random/internal/salted_seed_seq.h +165 -0
  617. package/deps/abseil-cpp/absl/random/internal/salted_seed_seq_test.cc +172 -0
  618. package/deps/abseil-cpp/absl/random/internal/seed_material.cc +249 -0
  619. package/deps/abseil-cpp/absl/random/internal/seed_material.h +104 -0
  620. package/deps/abseil-cpp/absl/random/internal/seed_material_test.cc +205 -0
  621. package/deps/abseil-cpp/absl/random/internal/sequence_urbg.h +60 -0
  622. package/deps/abseil-cpp/absl/random/internal/traits.h +149 -0
  623. package/deps/abseil-cpp/absl/random/internal/traits_test.cc +123 -0
  624. package/deps/abseil-cpp/absl/random/internal/uniform_helper.h +244 -0
  625. package/deps/abseil-cpp/absl/random/internal/uniform_helper_test.cc +279 -0
  626. package/deps/abseil-cpp/absl/random/internal/wide_multiply.h +95 -0
  627. package/deps/abseil-cpp/absl/random/internal/wide_multiply_test.cc +119 -0
  628. package/deps/abseil-cpp/absl/random/log_uniform_int_distribution.h +253 -0
  629. package/deps/abseil-cpp/absl/random/log_uniform_int_distribution_test.cc +277 -0
  630. package/deps/abseil-cpp/absl/random/mock_distributions.h +269 -0
  631. package/deps/abseil-cpp/absl/random/mock_distributions_test.cc +281 -0
  632. package/deps/abseil-cpp/absl/random/mocking_bit_gen.h +237 -0
  633. package/deps/abseil-cpp/absl/random/mocking_bit_gen_test.cc +403 -0
  634. package/deps/abseil-cpp/absl/random/poisson_distribution.h +262 -0
  635. package/deps/abseil-cpp/absl/random/poisson_distribution_test.cc +569 -0
  636. package/deps/abseil-cpp/absl/random/random.h +224 -0
  637. package/deps/abseil-cpp/absl/random/seed_gen_exception.cc +45 -0
  638. package/deps/abseil-cpp/absl/random/seed_gen_exception.h +55 -0
  639. package/deps/abseil-cpp/absl/random/seed_sequences.cc +33 -0
  640. package/deps/abseil-cpp/absl/random/seed_sequences.h +112 -0
  641. package/deps/abseil-cpp/absl/random/seed_sequences_test.cc +126 -0
  642. package/deps/abseil-cpp/absl/random/uniform_int_distribution.h +276 -0
  643. package/deps/abseil-cpp/absl/random/uniform_int_distribution_test.cc +259 -0
  644. package/deps/abseil-cpp/absl/random/uniform_real_distribution.h +204 -0
  645. package/deps/abseil-cpp/absl/random/uniform_real_distribution_test.cc +394 -0
  646. package/deps/abseil-cpp/absl/random/zipf_distribution.h +273 -0
  647. package/deps/abseil-cpp/absl/random/zipf_distribution_test.cc +423 -0
  648. package/deps/abseil-cpp/absl/status/BUILD.bazel +211 -0
  649. package/deps/abseil-cpp/absl/status/CMakeLists.txt +159 -0
  650. package/deps/abseil-cpp/absl/status/internal/status_internal.cc +251 -0
  651. package/deps/abseil-cpp/absl/status/internal/status_internal.h +133 -0
  652. package/deps/abseil-cpp/absl/status/internal/status_matchers.cc +69 -0
  653. package/deps/abseil-cpp/absl/status/internal/status_matchers.h +246 -0
  654. package/deps/abseil-cpp/absl/status/internal/statusor_internal.h +657 -0
  655. package/deps/abseil-cpp/absl/status/status.cc +421 -0
  656. package/deps/abseil-cpp/absl/status/status.h +948 -0
  657. package/deps/abseil-cpp/absl/status/status_benchmark.cc +37 -0
  658. package/deps/abseil-cpp/absl/status/status_matchers.h +166 -0
  659. package/deps/abseil-cpp/absl/status/status_matchers_test.cc +211 -0
  660. package/deps/abseil-cpp/absl/status/status_payload_printer.cc +36 -0
  661. package/deps/abseil-cpp/absl/status/status_payload_printer.h +52 -0
  662. package/deps/abseil-cpp/absl/status/status_test.cc +580 -0
  663. package/deps/abseil-cpp/absl/status/statusor.cc +106 -0
  664. package/deps/abseil-cpp/absl/status/statusor.h +743 -0
  665. package/deps/abseil-cpp/absl/status/statusor_benchmark.cc +480 -0
  666. package/deps/abseil-cpp/absl/status/statusor_test.cc +2124 -0
  667. package/deps/abseil-cpp/absl/strings/BUILD.bazel +1593 -0
  668. package/deps/abseil-cpp/absl/strings/CMakeLists.txt +1295 -0
  669. package/deps/abseil-cpp/absl/strings/ascii.cc +296 -0
  670. package/deps/abseil-cpp/absl/strings/ascii.h +289 -0
  671. package/deps/abseil-cpp/absl/strings/ascii_benchmark.cc +157 -0
  672. package/deps/abseil-cpp/absl/strings/ascii_test.cc +374 -0
  673. package/deps/abseil-cpp/absl/strings/atod_manual_test.cc +193 -0
  674. package/deps/abseil-cpp/absl/strings/char_formatting_test.cc +169 -0
  675. package/deps/abseil-cpp/absl/strings/charconv.cc +1442 -0
  676. package/deps/abseil-cpp/absl/strings/charconv.h +123 -0
  677. package/deps/abseil-cpp/absl/strings/charconv_benchmark.cc +203 -0
  678. package/deps/abseil-cpp/absl/strings/charconv_test.cc +787 -0
  679. package/deps/abseil-cpp/absl/strings/charset.h +163 -0
  680. package/deps/abseil-cpp/absl/strings/charset_benchmark.cc +57 -0
  681. package/deps/abseil-cpp/absl/strings/charset_test.cc +181 -0
  682. package/deps/abseil-cpp/absl/strings/cord.cc +1582 -0
  683. package/deps/abseil-cpp/absl/strings/cord.h +1763 -0
  684. package/deps/abseil-cpp/absl/strings/cord_analysis.cc +196 -0
  685. package/deps/abseil-cpp/absl/strings/cord_analysis.h +63 -0
  686. package/deps/abseil-cpp/absl/strings/cord_buffer.h +572 -0
  687. package/deps/abseil-cpp/absl/strings/cord_buffer_test.cc +322 -0
  688. package/deps/abseil-cpp/absl/strings/cord_test.cc +3421 -0
  689. package/deps/abseil-cpp/absl/strings/cord_test_helpers.h +122 -0
  690. package/deps/abseil-cpp/absl/strings/cordz_test.cc +468 -0
  691. package/deps/abseil-cpp/absl/strings/cordz_test_helpers.h +152 -0
  692. package/deps/abseil-cpp/absl/strings/escaping.cc +1035 -0
  693. package/deps/abseil-cpp/absl/strings/escaping.h +185 -0
  694. package/deps/abseil-cpp/absl/strings/escaping_benchmark.cc +124 -0
  695. package/deps/abseil-cpp/absl/strings/escaping_test.cc +760 -0
  696. package/deps/abseil-cpp/absl/strings/has_absl_stringify.h +64 -0
  697. package/deps/abseil-cpp/absl/strings/has_absl_stringify_test.cc +40 -0
  698. package/deps/abseil-cpp/absl/strings/has_ostream_operator.h +42 -0
  699. package/deps/abseil-cpp/absl/strings/has_ostream_operator_test.cc +41 -0
  700. package/deps/abseil-cpp/absl/strings/internal/append_and_overwrite.h +93 -0
  701. package/deps/abseil-cpp/absl/strings/internal/append_and_overwrite_test.cc +95 -0
  702. package/deps/abseil-cpp/absl/strings/internal/charconv_bigint.cc +357 -0
  703. package/deps/abseil-cpp/absl/strings/internal/charconv_bigint.h +433 -0
  704. package/deps/abseil-cpp/absl/strings/internal/charconv_bigint_test.cc +260 -0
  705. package/deps/abseil-cpp/absl/strings/internal/charconv_parse.cc +504 -0
  706. package/deps/abseil-cpp/absl/strings/internal/charconv_parse.h +99 -0
  707. package/deps/abseil-cpp/absl/strings/internal/charconv_parse_test.cc +357 -0
  708. package/deps/abseil-cpp/absl/strings/internal/cord_data_edge.h +63 -0
  709. package/deps/abseil-cpp/absl/strings/internal/cord_data_edge_test.cc +130 -0
  710. package/deps/abseil-cpp/absl/strings/internal/cord_internal.cc +70 -0
  711. package/deps/abseil-cpp/absl/strings/internal/cord_internal.h +942 -0
  712. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +1237 -0
  713. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree.h +944 -0
  714. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +187 -0
  715. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +267 -0
  716. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator_test.cc +346 -0
  717. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +69 -0
  718. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +212 -0
  719. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_reader_test.cc +293 -0
  720. package/deps/abseil-cpp/absl/strings/internal/cord_rep_btree_test.cc +1568 -0
  721. package/deps/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +64 -0
  722. package/deps/abseil-cpp/absl/strings/internal/cord_rep_consume.h +47 -0
  723. package/deps/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +56 -0
  724. package/deps/abseil-cpp/absl/strings/internal/cord_rep_crc.h +103 -0
  725. package/deps/abseil-cpp/absl/strings/internal/cord_rep_crc_test.cc +130 -0
  726. package/deps/abseil-cpp/absl/strings/internal/cord_rep_flat.h +195 -0
  727. package/deps/abseil-cpp/absl/strings/internal/cord_rep_test_util.h +205 -0
  728. package/deps/abseil-cpp/absl/strings/internal/cordz_functions.cc +102 -0
  729. package/deps/abseil-cpp/absl/strings/internal/cordz_functions.h +87 -0
  730. package/deps/abseil-cpp/absl/strings/internal/cordz_functions_test.cc +147 -0
  731. package/deps/abseil-cpp/absl/strings/internal/cordz_handle.cc +165 -0
  732. package/deps/abseil-cpp/absl/strings/internal/cordz_handle.h +98 -0
  733. package/deps/abseil-cpp/absl/strings/internal/cordz_handle_test.cc +265 -0
  734. package/deps/abseil-cpp/absl/strings/internal/cordz_info.cc +424 -0
  735. package/deps/abseil-cpp/absl/strings/internal/cordz_info.h +295 -0
  736. package/deps/abseil-cpp/absl/strings/internal/cordz_info_statistics_test.cc +510 -0
  737. package/deps/abseil-cpp/absl/strings/internal/cordz_info_test.cc +342 -0
  738. package/deps/abseil-cpp/absl/strings/internal/cordz_sample_token.cc +64 -0
  739. package/deps/abseil-cpp/absl/strings/internal/cordz_sample_token.h +97 -0
  740. package/deps/abseil-cpp/absl/strings/internal/cordz_sample_token_test.cc +208 -0
  741. package/deps/abseil-cpp/absl/strings/internal/cordz_statistics.h +88 -0
  742. package/deps/abseil-cpp/absl/strings/internal/cordz_update_scope.h +71 -0
  743. package/deps/abseil-cpp/absl/strings/internal/cordz_update_scope_test.cc +49 -0
  744. package/deps/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +123 -0
  745. package/deps/abseil-cpp/absl/strings/internal/cordz_update_tracker_test.cc +147 -0
  746. package/deps/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance.cc +99 -0
  747. package/deps/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance.h +35 -0
  748. package/deps/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance_benchmark.cc +56 -0
  749. package/deps/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance_test.cc +99 -0
  750. package/deps/abseil-cpp/absl/strings/internal/escaping.cc +209 -0
  751. package/deps/abseil-cpp/absl/strings/internal/escaping.h +59 -0
  752. package/deps/abseil-cpp/absl/strings/internal/escaping_test_common.h +133 -0
  753. package/deps/abseil-cpp/absl/strings/internal/generic_printer.cc +107 -0
  754. package/deps/abseil-cpp/absl/strings/internal/generic_printer.h +115 -0
  755. package/deps/abseil-cpp/absl/strings/internal/generic_printer_internal.h +423 -0
  756. package/deps/abseil-cpp/absl/strings/internal/generic_printer_test.cc +685 -0
  757. package/deps/abseil-cpp/absl/strings/internal/memutil.cc +48 -0
  758. package/deps/abseil-cpp/absl/strings/internal/memutil.h +40 -0
  759. package/deps/abseil-cpp/absl/strings/internal/memutil_benchmark.cc +127 -0
  760. package/deps/abseil-cpp/absl/strings/internal/memutil_test.cc +41 -0
  761. package/deps/abseil-cpp/absl/strings/internal/numbers_test_common.h +184 -0
  762. package/deps/abseil-cpp/absl/strings/internal/ostringstream.cc +43 -0
  763. package/deps/abseil-cpp/absl/strings/internal/ostringstream.h +114 -0
  764. package/deps/abseil-cpp/absl/strings/internal/ostringstream_benchmark.cc +105 -0
  765. package/deps/abseil-cpp/absl/strings/internal/ostringstream_test.cc +131 -0
  766. package/deps/abseil-cpp/absl/strings/internal/pow10_helper.cc +122 -0
  767. package/deps/abseil-cpp/absl/strings/internal/pow10_helper.h +40 -0
  768. package/deps/abseil-cpp/absl/strings/internal/pow10_helper_test.cc +122 -0
  769. package/deps/abseil-cpp/absl/strings/internal/resize_uninitialized.h +119 -0
  770. package/deps/abseil-cpp/absl/strings/internal/resize_uninitialized_test.cc +108 -0
  771. package/deps/abseil-cpp/absl/strings/internal/stl_type_traits.h +248 -0
  772. package/deps/abseil-cpp/absl/strings/internal/str_format/arg.cc +615 -0
  773. package/deps/abseil-cpp/absl/strings/internal/str_format/arg.h +661 -0
  774. package/deps/abseil-cpp/absl/strings/internal/str_format/arg_test.cc +162 -0
  775. package/deps/abseil-cpp/absl/strings/internal/str_format/bind.cc +275 -0
  776. package/deps/abseil-cpp/absl/strings/internal/str_format/bind.h +237 -0
  777. package/deps/abseil-cpp/absl/strings/internal/str_format/bind_test.cc +157 -0
  778. package/deps/abseil-cpp/absl/strings/internal/str_format/checker.h +98 -0
  779. package/deps/abseil-cpp/absl/strings/internal/str_format/checker_test.cc +176 -0
  780. package/deps/abseil-cpp/absl/strings/internal/str_format/constexpr_parser.h +357 -0
  781. package/deps/abseil-cpp/absl/strings/internal/str_format/convert_test.cc +1471 -0
  782. package/deps/abseil-cpp/absl/strings/internal/str_format/extension.cc +53 -0
  783. package/deps/abseil-cpp/absl/strings/internal/str_format/extension.h +456 -0
  784. package/deps/abseil-cpp/absl/strings/internal/str_format/extension_test.cc +110 -0
  785. package/deps/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +1945 -0
  786. package/deps/abseil-cpp/absl/strings/internal/str_format/float_conversion.h +37 -0
  787. package/deps/abseil-cpp/absl/strings/internal/str_format/output.cc +74 -0
  788. package/deps/abseil-cpp/absl/strings/internal/str_format/output.h +97 -0
  789. package/deps/abseil-cpp/absl/strings/internal/str_format/output_test.cc +79 -0
  790. package/deps/abseil-cpp/absl/strings/internal/str_format/parser.cc +140 -0
  791. package/deps/abseil-cpp/absl/strings/internal/str_format/parser.h +271 -0
  792. package/deps/abseil-cpp/absl/strings/internal/str_format/parser_test.cc +446 -0
  793. package/deps/abseil-cpp/absl/strings/internal/str_join_internal.h +341 -0
  794. package/deps/abseil-cpp/absl/strings/internal/str_split_internal.h +525 -0
  795. package/deps/abseil-cpp/absl/strings/internal/string_constant.h +67 -0
  796. package/deps/abseil-cpp/absl/strings/internal/string_constant_test.cc +60 -0
  797. package/deps/abseil-cpp/absl/strings/internal/stringify_sink.cc +28 -0
  798. package/deps/abseil-cpp/absl/strings/internal/stringify_sink.h +57 -0
  799. package/deps/abseil-cpp/absl/strings/internal/utf8.cc +148 -0
  800. package/deps/abseil-cpp/absl/strings/internal/utf8.h +64 -0
  801. package/deps/abseil-cpp/absl/strings/internal/utf8_test.cc +259 -0
  802. package/deps/abseil-cpp/absl/strings/match.cc +133 -0
  803. package/deps/abseil-cpp/absl/strings/match.h +129 -0
  804. package/deps/abseil-cpp/absl/strings/match_test.cc +291 -0
  805. package/deps/abseil-cpp/absl/strings/numbers.cc +1230 -0
  806. package/deps/abseil-cpp/absl/strings/numbers.h +359 -0
  807. package/deps/abseil-cpp/absl/strings/numbers_benchmark.cc +288 -0
  808. package/deps/abseil-cpp/absl/strings/numbers_test.cc +2324 -0
  809. package/deps/abseil-cpp/absl/strings/resize_and_overwrite.h +194 -0
  810. package/deps/abseil-cpp/absl/strings/resize_and_overwrite_test.cc +154 -0
  811. package/deps/abseil-cpp/absl/strings/str_cat.cc +247 -0
  812. package/deps/abseil-cpp/absl/strings/str_cat.h +633 -0
  813. package/deps/abseil-cpp/absl/strings/str_cat_benchmark.cc +288 -0
  814. package/deps/abseil-cpp/absl/strings/str_cat_test.cc +692 -0
  815. package/deps/abseil-cpp/absl/strings/str_format.h +887 -0
  816. package/deps/abseil-cpp/absl/strings/str_format_test.cc +1230 -0
  817. package/deps/abseil-cpp/absl/strings/str_join.h +301 -0
  818. package/deps/abseil-cpp/absl/strings/str_join_benchmark.cc +106 -0
  819. package/deps/abseil-cpp/absl/strings/str_join_test.cc +645 -0
  820. package/deps/abseil-cpp/absl/strings/str_replace.cc +91 -0
  821. package/deps/abseil-cpp/absl/strings/str_replace.h +222 -0
  822. package/deps/abseil-cpp/absl/strings/str_replace_benchmark.cc +121 -0
  823. package/deps/abseil-cpp/absl/strings/str_replace_test.cc +345 -0
  824. package/deps/abseil-cpp/absl/strings/str_split.cc +144 -0
  825. package/deps/abseil-cpp/absl/strings/str_split.h +582 -0
  826. package/deps/abseil-cpp/absl/strings/str_split_benchmark.cc +180 -0
  827. package/deps/abseil-cpp/absl/strings/str_split_test.cc +1069 -0
  828. package/deps/abseil-cpp/absl/strings/string_view.h +60 -0
  829. package/deps/abseil-cpp/absl/strings/string_view_test.cc +86 -0
  830. package/deps/abseil-cpp/absl/strings/strip.h +99 -0
  831. package/deps/abseil-cpp/absl/strings/strip_test.cc +198 -0
  832. package/deps/abseil-cpp/absl/strings/substitute.cc +187 -0
  833. package/deps/abseil-cpp/absl/strings/substitute.h +769 -0
  834. package/deps/abseil-cpp/absl/strings/substitute_benchmark.cc +158 -0
  835. package/deps/abseil-cpp/absl/strings/substitute_test.cc +288 -0
  836. package/deps/abseil-cpp/absl/synchronization/BUILD.bazel +410 -0
  837. package/deps/abseil-cpp/absl/synchronization/CMakeLists.txt +293 -0
  838. package/deps/abseil-cpp/absl/synchronization/barrier.cc +52 -0
  839. package/deps/abseil-cpp/absl/synchronization/barrier.h +79 -0
  840. package/deps/abseil-cpp/absl/synchronization/barrier_test.cc +75 -0
  841. package/deps/abseil-cpp/absl/synchronization/blocking_counter.cc +73 -0
  842. package/deps/abseil-cpp/absl/synchronization/blocking_counter.h +107 -0
  843. package/deps/abseil-cpp/absl/synchronization/blocking_counter_benchmark.cc +84 -0
  844. package/deps/abseil-cpp/absl/synchronization/blocking_counter_test.cc +146 -0
  845. package/deps/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +152 -0
  846. package/deps/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +56 -0
  847. package/deps/abseil-cpp/absl/synchronization/internal/futex.h +177 -0
  848. package/deps/abseil-cpp/absl/synchronization/internal/futex_waiter.cc +107 -0
  849. package/deps/abseil-cpp/absl/synchronization/internal/futex_waiter.h +63 -0
  850. package/deps/abseil-cpp/absl/synchronization/internal/graphcycles.cc +714 -0
  851. package/deps/abseil-cpp/absl/synchronization/internal/graphcycles.h +146 -0
  852. package/deps/abseil-cpp/absl/synchronization/internal/graphcycles_benchmark.cc +43 -0
  853. package/deps/abseil-cpp/absl/synchronization/internal/graphcycles_test.cc +483 -0
  854. package/deps/abseil-cpp/absl/synchronization/internal/kernel_timeout.cc +220 -0
  855. package/deps/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +178 -0
  856. package/deps/abseil-cpp/absl/synchronization/internal/kernel_timeout_test.cc +406 -0
  857. package/deps/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +106 -0
  858. package/deps/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +119 -0
  859. package/deps/abseil-cpp/absl/synchronization/internal/per_thread_sem_test.cc +194 -0
  860. package/deps/abseil-cpp/absl/synchronization/internal/pthread_waiter.cc +163 -0
  861. package/deps/abseil-cpp/absl/synchronization/internal/pthread_waiter.h +60 -0
  862. package/deps/abseil-cpp/absl/synchronization/internal/sem_waiter.cc +118 -0
  863. package/deps/abseil-cpp/absl/synchronization/internal/sem_waiter.h +65 -0
  864. package/deps/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.cc +87 -0
  865. package/deps/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.h +56 -0
  866. package/deps/abseil-cpp/absl/synchronization/internal/thread_pool.h +96 -0
  867. package/deps/abseil-cpp/absl/synchronization/internal/waiter.h +69 -0
  868. package/deps/abseil-cpp/absl/synchronization/internal/waiter_base.cc +38 -0
  869. package/deps/abseil-cpp/absl/synchronization/internal/waiter_base.h +90 -0
  870. package/deps/abseil-cpp/absl/synchronization/internal/waiter_test.cc +192 -0
  871. package/deps/abseil-cpp/absl/synchronization/internal/win32_waiter.cc +147 -0
  872. package/deps/abseil-cpp/absl/synchronization/internal/win32_waiter.h +72 -0
  873. package/deps/abseil-cpp/absl/synchronization/lifetime_test.cc +180 -0
  874. package/deps/abseil-cpp/absl/synchronization/mutex.cc +2820 -0
  875. package/deps/abseil-cpp/absl/synchronization/mutex.h +1352 -0
  876. package/deps/abseil-cpp/absl/synchronization/mutex_benchmark.cc +321 -0
  877. package/deps/abseil-cpp/absl/synchronization/mutex_method_pointer_test.cc +138 -0
  878. package/deps/abseil-cpp/absl/synchronization/mutex_test.cc +2065 -0
  879. package/deps/abseil-cpp/absl/synchronization/notification.cc +85 -0
  880. package/deps/abseil-cpp/absl/synchronization/notification.h +133 -0
  881. package/deps/abseil-cpp/absl/synchronization/notification_test.cc +230 -0
  882. package/deps/abseil-cpp/absl/time/BUILD.bazel +244 -0
  883. package/deps/abseil-cpp/absl/time/CMakeLists.txt +218 -0
  884. package/deps/abseil-cpp/absl/time/civil_time.cc +200 -0
  885. package/deps/abseil-cpp/absl/time/civil_time.h +589 -0
  886. package/deps/abseil-cpp/absl/time/civil_time_benchmark.cc +129 -0
  887. package/deps/abseil-cpp/absl/time/civil_time_test.cc +1351 -0
  888. package/deps/abseil-cpp/absl/time/clock.cc +603 -0
  889. package/deps/abseil-cpp/absl/time/clock.h +78 -0
  890. package/deps/abseil-cpp/absl/time/clock_benchmark.cc +74 -0
  891. package/deps/abseil-cpp/absl/time/clock_interface.cc +71 -0
  892. package/deps/abseil-cpp/absl/time/clock_interface.h +91 -0
  893. package/deps/abseil-cpp/absl/time/clock_interface_test.cc +128 -0
  894. package/deps/abseil-cpp/absl/time/clock_test.cc +122 -0
  895. package/deps/abseil-cpp/absl/time/duration.cc +918 -0
  896. package/deps/abseil-cpp/absl/time/duration_benchmark.cc +608 -0
  897. package/deps/abseil-cpp/absl/time/duration_test.cc +1901 -0
  898. package/deps/abseil-cpp/absl/time/flag_test.cc +147 -0
  899. package/deps/abseil-cpp/absl/time/format.cc +162 -0
  900. package/deps/abseil-cpp/absl/time/format_benchmark.cc +64 -0
  901. package/deps/abseil-cpp/absl/time/format_test.cc +441 -0
  902. package/deps/abseil-cpp/absl/time/internal/cctz/BUILD.bazel +195 -0
  903. package/deps/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time.h +332 -0
  904. package/deps/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +644 -0
  905. package/deps/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +460 -0
  906. package/deps/abseil-cpp/absl/time/internal/cctz/include/cctz/zone_info_source.h +102 -0
  907. package/deps/abseil-cpp/absl/time/internal/cctz/src/cctz_benchmark.cc +436 -0
  908. package/deps/abseil-cpp/absl/time/internal/cctz/src/civil_time_detail.cc +94 -0
  909. package/deps/abseil-cpp/absl/time/internal/cctz/src/civil_time_test.cc +1066 -0
  910. package/deps/abseil-cpp/absl/time/internal/cctz/src/test_time_zone_names.cc +515 -0
  911. package/deps/abseil-cpp/absl/time/internal/cctz/src/test_time_zone_names.h +33 -0
  912. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +140 -0
  913. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.h +52 -0
  914. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +1068 -0
  915. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_format_test.cc +1773 -0
  916. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +47 -0
  917. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.h +80 -0
  918. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +115 -0
  919. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +97 -0
  920. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +1070 -0
  921. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +128 -0
  922. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +333 -0
  923. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +60 -0
  924. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +217 -0
  925. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup_test.cc +918 -0
  926. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_name_win.cc +186 -0
  927. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_name_win.h +37 -0
  928. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.cc +159 -0
  929. package/deps/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.h +132 -0
  930. package/deps/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +120 -0
  931. package/deps/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +116 -0
  932. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/README.zoneinfo +38 -0
  933. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/version +1 -0
  934. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Abidjan +0 -0
  935. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Accra +0 -0
  936. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Addis_Ababa +0 -0
  937. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Algiers +0 -0
  938. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Asmara +0 -0
  939. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Asmera +0 -0
  940. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bamako +0 -0
  941. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bangui +0 -0
  942. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Banjul +0 -0
  943. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bissau +0 -0
  944. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Blantyre +0 -0
  945. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Brazzaville +0 -0
  946. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bujumbura +0 -0
  947. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Cairo +0 -0
  948. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Casablanca +0 -0
  949. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ceuta +0 -0
  950. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Conakry +0 -0
  951. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Dakar +0 -0
  952. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Dar_es_Salaam +0 -0
  953. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Djibouti +0 -0
  954. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Douala +0 -0
  955. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/El_Aaiun +0 -0
  956. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Freetown +0 -0
  957. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Gaborone +0 -0
  958. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Harare +0 -0
  959. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Johannesburg +0 -0
  960. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Juba +0 -0
  961. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kampala +0 -0
  962. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Khartoum +0 -0
  963. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kigali +0 -0
  964. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kinshasa +0 -0
  965. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lagos +0 -0
  966. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Libreville +0 -0
  967. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lome +0 -0
  968. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Luanda +0 -0
  969. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lubumbashi +0 -0
  970. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lusaka +0 -0
  971. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Malabo +0 -0
  972. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Maputo +0 -0
  973. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Maseru +0 -0
  974. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Mbabane +0 -0
  975. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Mogadishu +0 -0
  976. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Monrovia +0 -0
  977. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Nairobi +0 -0
  978. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ndjamena +0 -0
  979. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Niamey +0 -0
  980. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Nouakchott +0 -0
  981. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ouagadougou +0 -0
  982. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Porto-Novo +0 -0
  983. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Sao_Tome +0 -0
  984. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Timbuktu +0 -0
  985. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Tripoli +0 -0
  986. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Tunis +0 -0
  987. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Windhoek +0 -0
  988. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Adak +0 -0
  989. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Anchorage +0 -0
  990. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Anguilla +0 -0
  991. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Antigua +0 -0
  992. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Araguaina +0 -0
  993. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Buenos_Aires +0 -0
  994. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Catamarca +0 -0
  995. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/ComodRivadavia +0 -0
  996. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Cordoba +0 -0
  997. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Jujuy +0 -0
  998. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/La_Rioja +0 -0
  999. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Mendoza +0 -0
  1000. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Rio_Gallegos +0 -0
  1001. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Salta +0 -0
  1002. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/San_Juan +0 -0
  1003. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/San_Luis +0 -0
  1004. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Tucuman +0 -0
  1005. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Ushuaia +0 -0
  1006. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Aruba +0 -0
  1007. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Asuncion +0 -0
  1008. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Atikokan +0 -0
  1009. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Atka +0 -0
  1010. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bahia +0 -0
  1011. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bahia_Banderas +0 -0
  1012. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Barbados +0 -0
  1013. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Belem +0 -0
  1014. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Belize +0 -0
  1015. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Blanc-Sablon +0 -0
  1016. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Boa_Vista +0 -0
  1017. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bogota +0 -0
  1018. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Boise +0 -0
  1019. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Buenos_Aires +0 -0
  1020. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cambridge_Bay +0 -0
  1021. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Campo_Grande +0 -0
  1022. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cancun +0 -0
  1023. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Caracas +0 -0
  1024. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Catamarca +0 -0
  1025. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cayenne +0 -0
  1026. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cayman +0 -0
  1027. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Chicago +0 -0
  1028. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Chihuahua +0 -0
  1029. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ciudad_Juarez +0 -0
  1030. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Coral_Harbour +0 -0
  1031. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cordoba +0 -0
  1032. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Costa_Rica +0 -0
  1033. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Coyhaique +0 -0
  1034. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Creston +0 -0
  1035. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cuiaba +0 -0
  1036. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Curacao +0 -0
  1037. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Danmarkshavn +0 -0
  1038. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dawson +0 -0
  1039. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dawson_Creek +0 -0
  1040. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Denver +0 -0
  1041. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Detroit +0 -0
  1042. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dominica +0 -0
  1043. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Edmonton +0 -0
  1044. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Eirunepe +0 -0
  1045. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/El_Salvador +0 -0
  1046. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ensenada +0 -0
  1047. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fort_Nelson +0 -0
  1048. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fort_Wayne +0 -0
  1049. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fortaleza +0 -0
  1050. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Glace_Bay +0 -0
  1051. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Godthab +0 -0
  1052. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Goose_Bay +0 -0
  1053. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Grand_Turk +0 -0
  1054. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Grenada +0 -0
  1055. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guadeloupe +0 -0
  1056. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guatemala +0 -0
  1057. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guayaquil +0 -0
  1058. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guyana +0 -0
  1059. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Halifax +0 -0
  1060. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Havana +0 -0
  1061. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Hermosillo +0 -0
  1062. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Indianapolis +0 -0
  1063. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Knox +0 -0
  1064. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Marengo +0 -0
  1065. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Petersburg +0 -0
  1066. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Tell_City +0 -0
  1067. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Vevay +0 -0
  1068. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Vincennes +0 -0
  1069. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Winamac +0 -0
  1070. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indianapolis +0 -0
  1071. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Inuvik +0 -0
  1072. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Iqaluit +0 -0
  1073. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Jamaica +0 -0
  1074. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Jujuy +0 -0
  1075. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Juneau +0 -0
  1076. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kentucky/Louisville +0 -0
  1077. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kentucky/Monticello +0 -0
  1078. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Knox_IN +0 -0
  1079. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kralendijk +0 -0
  1080. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/La_Paz +0 -0
  1081. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Lima +0 -0
  1082. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Los_Angeles +0 -0
  1083. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Louisville +0 -0
  1084. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Lower_Princes +0 -0
  1085. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Maceio +0 -0
  1086. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Managua +0 -0
  1087. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Manaus +0 -0
  1088. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Marigot +0 -0
  1089. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Martinique +0 -0
  1090. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Matamoros +0 -0
  1091. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mazatlan +0 -0
  1092. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mendoza +0 -0
  1093. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Menominee +0 -0
  1094. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Merida +0 -0
  1095. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Metlakatla +0 -0
  1096. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mexico_City +0 -0
  1097. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Miquelon +0 -0
  1098. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Moncton +0 -0
  1099. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Monterrey +0 -0
  1100. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montevideo +0 -0
  1101. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montreal +0 -0
  1102. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montserrat +0 -0
  1103. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nassau +0 -0
  1104. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/New_York +0 -0
  1105. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nipigon +0 -0
  1106. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nome +0 -0
  1107. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Noronha +0 -0
  1108. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/Beulah +0 -0
  1109. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/Center +0 -0
  1110. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/New_Salem +0 -0
  1111. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nuuk +0 -0
  1112. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ojinaga +0 -0
  1113. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Panama +0 -0
  1114. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Pangnirtung +0 -0
  1115. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Paramaribo +0 -0
  1116. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Phoenix +0 -0
  1117. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Port-au-Prince +0 -0
  1118. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Port_of_Spain +0 -0
  1119. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Porto_Acre +0 -0
  1120. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Porto_Velho +0 -0
  1121. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Puerto_Rico +0 -0
  1122. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Punta_Arenas +0 -0
  1123. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rainy_River +0 -0
  1124. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rankin_Inlet +0 -0
  1125. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Recife +0 -0
  1126. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Regina +0 -0
  1127. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Resolute +0 -0
  1128. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rio_Branco +0 -0
  1129. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rosario +0 -0
  1130. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santa_Isabel +0 -0
  1131. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santarem +0 -0
  1132. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santiago +0 -0
  1133. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santo_Domingo +0 -0
  1134. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Sao_Paulo +0 -0
  1135. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Scoresbysund +0 -0
  1136. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Shiprock +0 -0
  1137. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Sitka +0 -0
  1138. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Barthelemy +0 -0
  1139. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Johns +0 -0
  1140. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Kitts +0 -0
  1141. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Lucia +0 -0
  1142. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Thomas +0 -0
  1143. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Vincent +0 -0
  1144. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Swift_Current +0 -0
  1145. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tegucigalpa +0 -0
  1146. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Thule +0 -0
  1147. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Thunder_Bay +0 -0
  1148. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tijuana +0 -0
  1149. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Toronto +0 -0
  1150. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tortola +0 -0
  1151. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Vancouver +0 -0
  1152. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Virgin +0 -0
  1153. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Whitehorse +0 -0
  1154. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Winnipeg +0 -0
  1155. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Yakutat +0 -0
  1156. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Yellowknife +0 -0
  1157. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Casey +0 -0
  1158. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Davis +0 -0
  1159. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/DumontDUrville +0 -0
  1160. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Macquarie +0 -0
  1161. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Mawson +0 -0
  1162. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/McMurdo +0 -0
  1163. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Palmer +0 -0
  1164. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Rothera +0 -0
  1165. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/South_Pole +0 -0
  1166. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Syowa +0 -0
  1167. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Troll +0 -0
  1168. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Vostok +0 -0
  1169. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Arctic/Longyearbyen +0 -0
  1170. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aden +0 -0
  1171. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Almaty +0 -0
  1172. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Amman +0 -0
  1173. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Anadyr +0 -0
  1174. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aqtau +0 -0
  1175. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aqtobe +0 -0
  1176. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ashgabat +0 -0
  1177. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ashkhabad +0 -0
  1178. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Atyrau +0 -0
  1179. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Baghdad +0 -0
  1180. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bahrain +0 -0
  1181. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Baku +0 -0
  1182. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bangkok +0 -0
  1183. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Barnaul +0 -0
  1184. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Beirut +0 -0
  1185. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bishkek +0 -0
  1186. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Brunei +0 -0
  1187. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Calcutta +0 -0
  1188. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chita +0 -0
  1189. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Choibalsan +0 -0
  1190. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chongqing +0 -0
  1191. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chungking +0 -0
  1192. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Colombo +0 -0
  1193. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dacca +0 -0
  1194. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Damascus +0 -0
  1195. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dhaka +0 -0
  1196. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dili +0 -0
  1197. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dubai +0 -0
  1198. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dushanbe +0 -0
  1199. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Famagusta +0 -0
  1200. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Gaza +0 -0
  1201. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Harbin +0 -0
  1202. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hebron +0 -0
  1203. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ho_Chi_Minh +0 -0
  1204. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hong_Kong +0 -0
  1205. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hovd +0 -0
  1206. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Irkutsk +0 -0
  1207. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Istanbul +0 -0
  1208. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jakarta +0 -0
  1209. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jayapura +0 -0
  1210. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jerusalem +0 -0
  1211. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kabul +0 -0
  1212. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kamchatka +0 -0
  1213. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Karachi +0 -0
  1214. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kashgar +0 -0
  1215. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kathmandu +0 -0
  1216. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Katmandu +0 -0
  1217. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Khandyga +0 -0
  1218. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kolkata +0 -0
  1219. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Krasnoyarsk +0 -0
  1220. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuala_Lumpur +0 -0
  1221. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuching +0 -0
  1222. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuwait +0 -0
  1223. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Macao +0 -0
  1224. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Macau +0 -0
  1225. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Magadan +0 -0
  1226. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Makassar +0 -0
  1227. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Manila +0 -0
  1228. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Muscat +0 -0
  1229. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Nicosia +0 -0
  1230. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Novokuznetsk +0 -0
  1231. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Novosibirsk +0 -0
  1232. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Omsk +0 -0
  1233. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Oral +0 -0
  1234. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Phnom_Penh +0 -0
  1235. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Pontianak +0 -0
  1236. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Pyongyang +0 -0
  1237. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qatar +0 -0
  1238. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qostanay +0 -0
  1239. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qyzylorda +0 -0
  1240. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Rangoon +0 -0
  1241. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Riyadh +0 -0
  1242. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Saigon +0 -0
  1243. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Sakhalin +0 -0
  1244. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Samarkand +0 -0
  1245. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Seoul +0 -0
  1246. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Shanghai +0 -0
  1247. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Singapore +0 -0
  1248. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Srednekolymsk +0 -0
  1249. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Taipei +0 -0
  1250. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tashkent +0 -0
  1251. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tbilisi +0 -0
  1252. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tehran +0 -0
  1253. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tel_Aviv +0 -0
  1254. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Thimbu +0 -0
  1255. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Thimphu +0 -0
  1256. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tokyo +0 -0
  1257. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tomsk +0 -0
  1258. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ujung_Pandang +0 -0
  1259. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ulaanbaatar +0 -0
  1260. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ulan_Bator +0 -0
  1261. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Urumqi +0 -0
  1262. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ust-Nera +0 -0
  1263. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Vientiane +0 -0
  1264. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Vladivostok +0 -0
  1265. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yakutsk +0 -0
  1266. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yangon +0 -0
  1267. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yekaterinburg +0 -0
  1268. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yerevan +0 -0
  1269. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Azores +0 -0
  1270. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Bermuda +0 -0
  1271. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Canary +0 -0
  1272. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Cape_Verde +0 -0
  1273. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Faeroe +0 -0
  1274. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Faroe +0 -0
  1275. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Jan_Mayen +0 -0
  1276. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Madeira +0 -0
  1277. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Reykjavik +0 -0
  1278. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/South_Georgia +0 -0
  1279. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/St_Helena +0 -0
  1280. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Stanley +0 -0
  1281. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/ACT +0 -0
  1282. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Adelaide +0 -0
  1283. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Brisbane +0 -0
  1284. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Broken_Hill +0 -0
  1285. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Canberra +0 -0
  1286. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Currie +0 -0
  1287. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Darwin +0 -0
  1288. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Eucla +0 -0
  1289. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Hobart +0 -0
  1290. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/LHI +0 -0
  1291. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Lindeman +0 -0
  1292. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Lord_Howe +0 -0
  1293. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Melbourne +0 -0
  1294. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/NSW +0 -0
  1295. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/North +0 -0
  1296. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Perth +0 -0
  1297. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Queensland +0 -0
  1298. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/South +0 -0
  1299. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Sydney +0 -0
  1300. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Tasmania +0 -0
  1301. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Victoria +0 -0
  1302. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/West +0 -0
  1303. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Yancowinna +0 -0
  1304. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/Acre +0 -0
  1305. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/DeNoronha +0 -0
  1306. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/East +0 -0
  1307. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/West +0 -0
  1308. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/CET +0 -0
  1309. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/CST6CDT +0 -0
  1310. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Atlantic +0 -0
  1311. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Central +0 -0
  1312. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Eastern +0 -0
  1313. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Mountain +0 -0
  1314. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Newfoundland +0 -0
  1315. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Pacific +0 -0
  1316. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Saskatchewan +0 -0
  1317. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Yukon +0 -0
  1318. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Chile/Continental +0 -0
  1319. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Chile/EasterIsland +0 -0
  1320. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Cuba +0 -0
  1321. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EET +0 -0
  1322. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EST +0 -0
  1323. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EST5EDT +0 -0
  1324. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Egypt +0 -0
  1325. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Eire +0 -0
  1326. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT +0 -0
  1327. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+0 +0 -0
  1328. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+1 +0 -0
  1329. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+10 +0 -0
  1330. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+11 +0 -0
  1331. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+12 +0 -0
  1332. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+2 +0 -0
  1333. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+3 +0 -0
  1334. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+4 +0 -0
  1335. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+5 +0 -0
  1336. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+6 +0 -0
  1337. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+7 +0 -0
  1338. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+8 +0 -0
  1339. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+9 +0 -0
  1340. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-0 +0 -0
  1341. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-1 +0 -0
  1342. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-10 +0 -0
  1343. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-11 +0 -0
  1344. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-12 +0 -0
  1345. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-13 +0 -0
  1346. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-14 +0 -0
  1347. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-2 +0 -0
  1348. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-3 +0 -0
  1349. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-4 +0 -0
  1350. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-5 +0 -0
  1351. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-6 +0 -0
  1352. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-7 +0 -0
  1353. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-8 +0 -0
  1354. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-9 +0 -0
  1355. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT0 +0 -0
  1356. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Greenwich +0 -0
  1357. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/UCT +0 -0
  1358. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/UTC +0 -0
  1359. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Universal +0 -0
  1360. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Zulu +0 -0
  1361. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Amsterdam +0 -0
  1362. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Andorra +0 -0
  1363. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Astrakhan +0 -0
  1364. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Athens +0 -0
  1365. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Belfast +0 -0
  1366. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Belgrade +0 -0
  1367. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Berlin +0 -0
  1368. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Bratislava +0 -0
  1369. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Brussels +0 -0
  1370. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Bucharest +0 -0
  1371. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Budapest +0 -0
  1372. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Busingen +0 -0
  1373. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Chisinau +0 -0
  1374. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Copenhagen +0 -0
  1375. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Dublin +0 -0
  1376. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Gibraltar +0 -0
  1377. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Guernsey +0 -0
  1378. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Helsinki +0 -0
  1379. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Isle_of_Man +0 -0
  1380. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Istanbul +0 -0
  1381. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Jersey +0 -0
  1382. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kaliningrad +0 -0
  1383. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kiev +0 -0
  1384. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kirov +0 -0
  1385. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kyiv +0 -0
  1386. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Lisbon +0 -0
  1387. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Ljubljana +0 -0
  1388. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/London +0 -0
  1389. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Luxembourg +0 -0
  1390. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Madrid +0 -0
  1391. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Malta +0 -0
  1392. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Mariehamn +0 -0
  1393. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Minsk +0 -0
  1394. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Monaco +0 -0
  1395. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Moscow +0 -0
  1396. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Nicosia +0 -0
  1397. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Oslo +0 -0
  1398. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Paris +0 -0
  1399. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Podgorica +0 -0
  1400. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Prague +0 -0
  1401. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Riga +0 -0
  1402. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Rome +0 -0
  1403. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Samara +0 -0
  1404. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/San_Marino +0 -0
  1405. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Sarajevo +0 -0
  1406. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Saratov +0 -0
  1407. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Simferopol +0 -0
  1408. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Skopje +0 -0
  1409. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Sofia +0 -0
  1410. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Stockholm +0 -0
  1411. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tallinn +0 -0
  1412. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tirane +0 -0
  1413. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tiraspol +0 -0
  1414. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Ulyanovsk +0 -0
  1415. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Uzhgorod +0 -0
  1416. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vaduz +0 -0
  1417. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vatican +0 -0
  1418. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vienna +0 -0
  1419. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vilnius +0 -0
  1420. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Volgograd +0 -0
  1421. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Warsaw +0 -0
  1422. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zagreb +0 -0
  1423. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zaporozhye +0 -0
  1424. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zurich +0 -0
  1425. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Factory +0 -0
  1426. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GB +0 -0
  1427. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GB-Eire +0 -0
  1428. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT +0 -0
  1429. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT+0 +0 -0
  1430. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT-0 +0 -0
  1431. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT0 +0 -0
  1432. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Greenwich +0 -0
  1433. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/HST +0 -0
  1434. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Hongkong +0 -0
  1435. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Iceland +0 -0
  1436. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Antananarivo +0 -0
  1437. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Chagos +0 -0
  1438. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Christmas +0 -0
  1439. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Cocos +0 -0
  1440. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Comoro +0 -0
  1441. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Kerguelen +0 -0
  1442. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mahe +0 -0
  1443. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Maldives +0 -0
  1444. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mauritius +0 -0
  1445. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mayotte +0 -0
  1446. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Reunion +0 -0
  1447. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Iran +0 -0
  1448. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Israel +0 -0
  1449. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Jamaica +0 -0
  1450. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Japan +0 -0
  1451. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Kwajalein +0 -0
  1452. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Libya +0 -0
  1453. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MET +0 -0
  1454. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MST +0 -0
  1455. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MST7MDT +0 -0
  1456. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/BajaNorte +0 -0
  1457. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/BajaSur +0 -0
  1458. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/General +0 -0
  1459. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/NZ +0 -0
  1460. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/NZ-CHAT +0 -0
  1461. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Navajo +0 -0
  1462. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/PRC +0 -0
  1463. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/PST8PDT +0 -0
  1464. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Apia +0 -0
  1465. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Auckland +0 -0
  1466. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Bougainville +0 -0
  1467. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Chatham +0 -0
  1468. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Chuuk +0 -0
  1469. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Easter +0 -0
  1470. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Efate +0 -0
  1471. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Enderbury +0 -0
  1472. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Fakaofo +0 -0
  1473. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Fiji +0 -0
  1474. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Funafuti +0 -0
  1475. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Galapagos +0 -0
  1476. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Gambier +0 -0
  1477. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Guadalcanal +0 -0
  1478. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Guam +0 -0
  1479. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Honolulu +0 -0
  1480. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Johnston +0 -0
  1481. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kanton +0 -0
  1482. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kiritimati +0 -0
  1483. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kosrae +0 -0
  1484. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kwajalein +0 -0
  1485. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Majuro +0 -0
  1486. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Marquesas +0 -0
  1487. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Midway +0 -0
  1488. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Nauru +0 -0
  1489. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Niue +0 -0
  1490. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Norfolk +0 -0
  1491. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Noumea +0 -0
  1492. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pago_Pago +0 -0
  1493. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Palau +0 -0
  1494. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pitcairn +0 -0
  1495. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pohnpei +0 -0
  1496. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Ponape +0 -0
  1497. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Port_Moresby +0 -0
  1498. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Rarotonga +0 -0
  1499. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Saipan +0 -0
  1500. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Samoa +0 -0
  1501. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tahiti +0 -0
  1502. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tarawa +0 -0
  1503. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tongatapu +0 -0
  1504. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Truk +0 -0
  1505. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Wake +0 -0
  1506. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Wallis +0 -0
  1507. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Yap +0 -0
  1508. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Poland +0 -0
  1509. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Portugal +0 -0
  1510. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/ROC +0 -0
  1511. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/ROK +0 -0
  1512. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Singapore +0 -0
  1513. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Turkey +0 -0
  1514. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/UCT +0 -0
  1515. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Alaska +0 -0
  1516. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Aleutian +0 -0
  1517. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Arizona +0 -0
  1518. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Central +0 -0
  1519. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/East-Indiana +0 -0
  1520. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Eastern +0 -0
  1521. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Hawaii +0 -0
  1522. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Indiana-Starke +0 -0
  1523. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Michigan +0 -0
  1524. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Mountain +0 -0
  1525. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Pacific +0 -0
  1526. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Samoa +0 -0
  1527. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/UTC +0 -0
  1528. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Universal +0 -0
  1529. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/W-SU +0 -0
  1530. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/WET +0 -0
  1531. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Zulu +0 -0
  1532. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/iso3166.tab +279 -0
  1533. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/zone1970.tab +375 -0
  1534. package/deps/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/zonenow.tab +296 -0
  1535. package/deps/abseil-cpp/absl/time/internal/get_current_time_chrono.inc +31 -0
  1536. package/deps/abseil-cpp/absl/time/internal/get_current_time_posix.inc +24 -0
  1537. package/deps/abseil-cpp/absl/time/internal/test_util.cc +32 -0
  1538. package/deps/abseil-cpp/absl/time/internal/test_util.h +33 -0
  1539. package/deps/abseil-cpp/absl/time/simulated_clock.cc +225 -0
  1540. package/deps/abseil-cpp/absl/time/simulated_clock.h +108 -0
  1541. package/deps/abseil-cpp/absl/time/simulated_clock_test.cc +614 -0
  1542. package/deps/abseil-cpp/absl/time/time.cc +507 -0
  1543. package/deps/abseil-cpp/absl/time/time.h +1926 -0
  1544. package/deps/abseil-cpp/absl/time/time_benchmark.cc +321 -0
  1545. package/deps/abseil-cpp/absl/time/time_test.cc +1365 -0
  1546. package/deps/abseil-cpp/absl/time/time_zone_test.cc +97 -0
  1547. package/deps/abseil-cpp/absl/types/BUILD.bazel +166 -0
  1548. package/deps/abseil-cpp/absl/types/CMakeLists.txt +179 -0
  1549. package/deps/abseil-cpp/absl/types/any.h +44 -0
  1550. package/deps/abseil-cpp/absl/types/compare.h +506 -0
  1551. package/deps/abseil-cpp/absl/types/compare_test.cc +300 -0
  1552. package/deps/abseil-cpp/absl/types/internal/span.h +141 -0
  1553. package/deps/abseil-cpp/absl/types/optional.h +41 -0
  1554. package/deps/abseil-cpp/absl/types/span.h +830 -0
  1555. package/deps/abseil-cpp/absl/types/span_test.cc +915 -0
  1556. package/deps/abseil-cpp/absl/types/variant.h +82 -0
  1557. package/deps/abseil-cpp/absl/types/variant_test.cc +164 -0
  1558. package/deps/abseil-cpp/absl/utility/BUILD.bazel +46 -0
  1559. package/deps/abseil-cpp/absl/utility/CMakeLists.txt +28 -0
  1560. package/deps/abseil-cpp/absl/utility/utility.h +68 -0
  1561. package/deps/abseil-cpp/ci/absl_alternate_options.h +28 -0
  1562. package/deps/abseil-cpp/ci/cmake_common.sh +19 -0
  1563. package/deps/abseil-cpp/ci/cmake_install_test.sh +64 -0
  1564. package/deps/abseil-cpp/ci/linux_arm_clang-latest_libcxx_bazel.sh +106 -0
  1565. package/deps/abseil-cpp/ci/linux_clang-latest_libcxx_asan_bazel.sh +114 -0
  1566. package/deps/abseil-cpp/ci/linux_clang-latest_libcxx_bazel.sh +107 -0
  1567. package/deps/abseil-cpp/ci/linux_clang-latest_libcxx_tsan_bazel.sh +106 -0
  1568. package/deps/abseil-cpp/ci/linux_clang-latest_libstdcxx_bazel.sh +104 -0
  1569. package/deps/abseil-cpp/ci/linux_docker_containers.sh +22 -0
  1570. package/deps/abseil-cpp/ci/linux_gcc-floor_libstdcxx_bazel.sh +100 -0
  1571. package/deps/abseil-cpp/ci/linux_gcc-latest_libstdcxx_bazel.sh +105 -0
  1572. package/deps/abseil-cpp/ci/linux_gcc-latest_libstdcxx_cmake.sh +85 -0
  1573. package/deps/abseil-cpp/ci/linux_gcc_alpine_cmake.sh +85 -0
  1574. package/deps/abseil-cpp/ci/macos_xcode_bazel.sh +70 -0
  1575. package/deps/abseil-cpp/ci/macos_xcode_cmake.sh +78 -0
  1576. package/deps/abseil-cpp/ci/windows_clangcl_bazel.bat +70 -0
  1577. package/deps/abseil-cpp/ci/windows_msvc_bazel.bat +61 -0
  1578. package/deps/abseil-cpp/ci/windows_msvc_cmake.bat +69 -0
  1579. package/deps/abseil-cpp/conanfile.py +51 -0
  1580. package/deps/abseil-cpp/create_lts.py +139 -0
  1581. package/deps/re2/.bazelrc +20 -0
  1582. package/deps/re2/.bcr/metadata.template.json +16 -0
  1583. package/deps/re2/.bcr/presubmit.yml +57 -0
  1584. package/deps/re2/.bcr/source.template.json +5 -0
  1585. package/deps/re2/BUILD.bazel +463 -0
  1586. package/deps/re2/CMakeLists.txt +283 -0
  1587. package/deps/re2/LICENSE +27 -0
  1588. package/deps/re2/MODULE.bazel +29 -0
  1589. package/deps/re2/Makefile +408 -0
  1590. package/deps/re2/WORKSPACE.bazel +7 -0
  1591. package/deps/re2/WORKSPACE.bzlmod +7 -0
  1592. package/deps/re2/app/BUILD.bazel +24 -0
  1593. package/deps/re2/app/_re2.cc +94 -0
  1594. package/deps/re2/app/_re2.d.ts +23 -0
  1595. package/deps/re2/app/app.ts +111 -0
  1596. package/deps/re2/app/build.sh +32 -0
  1597. package/deps/re2/app/index.html +5 -0
  1598. package/deps/re2/app/package.json +14 -0
  1599. package/deps/re2/app/rollup.config.js +28 -0
  1600. package/deps/re2/app/tsconfig.json +17 -0
  1601. package/deps/re2/benchlog/benchplot.py +98 -0
  1602. package/deps/re2/benchlog/mktable +155 -0
  1603. package/deps/re2/doc/mksyntaxgo +42 -0
  1604. package/deps/re2/doc/mksyntaxhtml +42 -0
  1605. package/deps/re2/doc/mksyntaxwiki +36 -0
  1606. package/deps/re2/doc/syntax.html +477 -0
  1607. package/deps/re2/doc/syntax.txt +463 -0
  1608. package/deps/re2/lib/git/commit-msg.hook +104 -0
  1609. package/deps/re2/libre2.symbols +16 -0
  1610. package/deps/re2/libre2.symbols.darwin +12 -0
  1611. package/deps/re2/python/BUILD.bazel +80 -0
  1612. package/deps/re2/python/_re2.cc +352 -0
  1613. package/deps/re2/python/re2.py +583 -0
  1614. package/deps/re2/python/re2_test.py +495 -0
  1615. package/deps/re2/python/setup.py +159 -0
  1616. package/deps/re2/python/toolchains/generate.py +100 -0
  1617. package/deps/re2/re2/bitmap256.cc +43 -0
  1618. package/deps/re2/re2/bitmap256.h +88 -0
  1619. package/deps/re2/re2/bitstate.cc +389 -0
  1620. package/deps/re2/re2/compile.cc +1265 -0
  1621. package/deps/re2/re2/dfa.cc +2135 -0
  1622. package/deps/re2/re2/filtered_re2.cc +138 -0
  1623. package/deps/re2/re2/filtered_re2.h +115 -0
  1624. package/deps/re2/re2/fuzzing/re2_fuzzer.cc +284 -0
  1625. package/deps/re2/re2/make_perl_groups.pl +116 -0
  1626. package/deps/re2/re2/make_unicode_casefold.py +151 -0
  1627. package/deps/re2/re2/make_unicode_groups.py +117 -0
  1628. package/deps/re2/re2/mimics_pcre.cc +196 -0
  1629. package/deps/re2/re2/nfa.cc +714 -0
  1630. package/deps/re2/re2/onepass.cc +623 -0
  1631. package/deps/re2/re2/parse.cc +2529 -0
  1632. package/deps/re2/re2/perl_groups.cc +119 -0
  1633. package/deps/re2/re2/pod_array.h +55 -0
  1634. package/deps/re2/re2/prefilter.cc +711 -0
  1635. package/deps/re2/re2/prefilter.h +168 -0
  1636. package/deps/re2/re2/prefilter_tree.cc +376 -0
  1637. package/deps/re2/re2/prefilter_tree.h +153 -0
  1638. package/deps/re2/re2/prog.cc +1181 -0
  1639. package/deps/re2/re2/prog.h +493 -0
  1640. package/deps/re2/re2/re2.cc +1355 -0
  1641. package/deps/re2/re2/re2.h +1074 -0
  1642. package/deps/re2/re2/regexp.cc +1004 -0
  1643. package/deps/re2/re2/regexp.h +693 -0
  1644. package/deps/re2/re2/set.cc +185 -0
  1645. package/deps/re2/re2/set.h +91 -0
  1646. package/deps/re2/re2/simplify.cc +689 -0
  1647. package/deps/re2/re2/sparse_array.h +394 -0
  1648. package/deps/re2/re2/sparse_set.h +266 -0
  1649. package/deps/re2/re2/stringpiece.h +18 -0
  1650. package/deps/re2/re2/testing/backtrack.cc +274 -0
  1651. package/deps/re2/re2/testing/charclass_test.cc +228 -0
  1652. package/deps/re2/re2/testing/compile_test.cc +431 -0
  1653. package/deps/re2/re2/testing/dfa_test.cc +376 -0
  1654. package/deps/re2/re2/testing/dump.cc +172 -0
  1655. package/deps/re2/re2/testing/exhaustive1_test.cc +40 -0
  1656. package/deps/re2/re2/testing/exhaustive2_test.cc +72 -0
  1657. package/deps/re2/re2/testing/exhaustive3_test.cc +100 -0
  1658. package/deps/re2/re2/testing/exhaustive_test.cc +35 -0
  1659. package/deps/re2/re2/testing/exhaustive_tester.cc +204 -0
  1660. package/deps/re2/re2/testing/exhaustive_tester.h +105 -0
  1661. package/deps/re2/re2/testing/filtered_re2_test.cc +343 -0
  1662. package/deps/re2/re2/testing/mimics_pcre_test.cc +79 -0
  1663. package/deps/re2/re2/testing/null_walker.cc +48 -0
  1664. package/deps/re2/re2/testing/parse_test.cc +586 -0
  1665. package/deps/re2/re2/testing/possible_match_test.cc +251 -0
  1666. package/deps/re2/re2/testing/random_test.cc +102 -0
  1667. package/deps/re2/re2/testing/re2_arg_test.cc +182 -0
  1668. package/deps/re2/re2/testing/re2_test.cc +1699 -0
  1669. package/deps/re2/re2/testing/regexp_benchmark.cc +1605 -0
  1670. package/deps/re2/re2/testing/regexp_generator.cc +284 -0
  1671. package/deps/re2/re2/testing/regexp_generator.h +77 -0
  1672. package/deps/re2/re2/testing/regexp_test.cc +87 -0
  1673. package/deps/re2/re2/testing/required_prefix_test.cc +201 -0
  1674. package/deps/re2/re2/testing/search_test.cc +338 -0
  1675. package/deps/re2/re2/testing/set_test.cc +235 -0
  1676. package/deps/re2/re2/testing/simplify_test.cc +289 -0
  1677. package/deps/re2/re2/testing/string_generator.cc +144 -0
  1678. package/deps/re2/re2/testing/string_generator.h +76 -0
  1679. package/deps/re2/re2/testing/string_generator_test.cc +114 -0
  1680. package/deps/re2/re2/testing/tester.cc +690 -0
  1681. package/deps/re2/re2/testing/tester.h +121 -0
  1682. package/deps/re2/re2/tostring.cc +351 -0
  1683. package/deps/re2/re2/unicode.py +284 -0
  1684. package/deps/re2/re2/unicode_casefold.cc +604 -0
  1685. package/deps/re2/re2/unicode_casefold.h +77 -0
  1686. package/deps/re2/re2/unicode_groups.cc +6517 -0
  1687. package/deps/re2/re2/unicode_groups.h +66 -0
  1688. package/deps/re2/re2/walker-inl.h +249 -0
  1689. package/deps/re2/re2.pc.in +9 -0
  1690. package/deps/re2/re2Config.cmake.in +26 -0
  1691. package/deps/re2/runtests +33 -0
  1692. package/deps/re2/testinstall.cc +27 -0
  1693. package/deps/re2/ucs2.diff +567 -0
  1694. package/deps/re2/util/malloc_counter.h +19 -0
  1695. package/deps/re2/util/pcre.cc +957 -0
  1696. package/deps/re2/util/pcre.h +671 -0
  1697. package/deps/re2/util/rune.cc +260 -0
  1698. package/deps/re2/util/strutil.cc +26 -0
  1699. package/deps/re2/util/strutil.h +16 -0
  1700. package/deps/re2/util/utf.h +44 -0
  1701. package/index.js +14 -5
  1702. package/package.json +1 -1
  1703. package/prebuilds/darwin-arm64/@nxtedition+rocksdb.node +0 -0
  1704. package/prebuilds/linux-x64/@nxtedition+rocksdb.node +0 -0
  1705. package/util.h +10 -16
@@ -0,0 +1,1763 @@
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 &current_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_