re2 1.20.0 → 1.20.2

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 (1492) hide show
  1. package/.github/actions/linux-alpine-node-16/entrypoint.sh +2 -0
  2. package/.github/actions/linux-alpine-node-18/entrypoint.sh +3 -1
  3. package/.github/actions/linux-alpine-node-20/entrypoint.sh +3 -1
  4. package/.github/actions/linux-node-12/entrypoint.sh +2 -0
  5. package/.github/actions/linux-node-18/entrypoint.sh +3 -1
  6. package/.github/actions/linux-node-20/entrypoint.sh +3 -1
  7. package/README.md +2 -0
  8. package/binding.gyp +1 -0
  9. package/package.json +2 -2
  10. package/vendor/abseil-cpp/.clang-format +4 -0
  11. package/vendor/abseil-cpp/.github/ISSUE_TEMPLATE/00-bug_report.yml +53 -0
  12. package/vendor/abseil-cpp/.github/ISSUE_TEMPLATE/config.yml +5 -0
  13. package/vendor/abseil-cpp/ABSEIL_ISSUE_TEMPLATE.md +22 -0
  14. package/vendor/abseil-cpp/AUTHORS +6 -0
  15. package/vendor/abseil-cpp/BUILD.bazel +25 -0
  16. package/vendor/abseil-cpp/CMake/AbseilDll.cmake +809 -0
  17. package/vendor/abseil-cpp/CMake/AbseilHelpers.cmake +466 -0
  18. package/vendor/abseil-cpp/CMake/Googletest/CMakeLists.txt.in +14 -0
  19. package/vendor/abseil-cpp/CMake/Googletest/DownloadGTest.cmake +41 -0
  20. package/vendor/abseil-cpp/CMake/README.md +188 -0
  21. package/vendor/abseil-cpp/CMake/abslConfig.cmake.in +8 -0
  22. package/vendor/abseil-cpp/CMake/install_test_project/CMakeLists.txt +25 -0
  23. package/vendor/abseil-cpp/CMake/install_test_project/simple.cc +32 -0
  24. package/vendor/abseil-cpp/CMake/install_test_project/test.sh +112 -0
  25. package/vendor/abseil-cpp/CMakeLists.txt +239 -0
  26. package/vendor/abseil-cpp/CONTRIBUTING.md +141 -0
  27. package/vendor/abseil-cpp/FAQ.md +167 -0
  28. package/vendor/abseil-cpp/LICENSE +203 -0
  29. package/vendor/abseil-cpp/README.md +163 -0
  30. package/vendor/abseil-cpp/UPGRADES.md +17 -0
  31. package/vendor/abseil-cpp/WORKSPACE +62 -0
  32. package/vendor/abseil-cpp/absl/BUILD.bazel +125 -0
  33. package/vendor/abseil-cpp/absl/CMakeLists.txt +44 -0
  34. package/vendor/abseil-cpp/absl/abseil.podspec.gen.py +229 -0
  35. package/vendor/abseil-cpp/absl/algorithm/BUILD.bazel +92 -0
  36. package/vendor/abseil-cpp/absl/algorithm/CMakeLists.txt +70 -0
  37. package/vendor/abseil-cpp/absl/algorithm/algorithm.h +159 -0
  38. package/vendor/abseil-cpp/absl/algorithm/algorithm_test.cc +191 -0
  39. package/vendor/abseil-cpp/absl/algorithm/container.h +1773 -0
  40. package/vendor/abseil-cpp/absl/algorithm/container_test.cc +1127 -0
  41. package/vendor/abseil-cpp/absl/algorithm/equal_benchmark.cc +126 -0
  42. package/vendor/abseil-cpp/absl/base/BUILD.bazel +783 -0
  43. package/vendor/abseil-cpp/absl/base/CMakeLists.txt +685 -0
  44. package/vendor/abseil-cpp/absl/base/attributes.h +782 -0
  45. package/vendor/abseil-cpp/absl/base/bit_cast_test.cc +109 -0
  46. package/vendor/abseil-cpp/absl/base/call_once.h +219 -0
  47. package/vendor/abseil-cpp/absl/base/call_once_test.cc +107 -0
  48. package/vendor/abseil-cpp/absl/base/casts.h +180 -0
  49. package/vendor/abseil-cpp/absl/base/config.h +954 -0
  50. package/vendor/abseil-cpp/absl/base/config_test.cc +60 -0
  51. package/vendor/abseil-cpp/absl/base/const_init.h +76 -0
  52. package/vendor/abseil-cpp/absl/base/dynamic_annotations.h +471 -0
  53. package/vendor/abseil-cpp/absl/base/exception_safety_testing_test.cc +959 -0
  54. package/vendor/abseil-cpp/absl/base/inline_variable_test.cc +64 -0
  55. package/vendor/abseil-cpp/absl/base/inline_variable_test_a.cc +27 -0
  56. package/vendor/abseil-cpp/absl/base/inline_variable_test_b.cc +27 -0
  57. package/vendor/abseil-cpp/absl/base/internal/atomic_hook.h +200 -0
  58. package/vendor/abseil-cpp/absl/base/internal/atomic_hook_test.cc +97 -0
  59. package/vendor/abseil-cpp/absl/base/internal/atomic_hook_test_helper.cc +32 -0
  60. package/vendor/abseil-cpp/absl/base/internal/atomic_hook_test_helper.h +34 -0
  61. package/vendor/abseil-cpp/absl/base/internal/cmake_thread_test.cc +22 -0
  62. package/vendor/abseil-cpp/absl/base/internal/cycleclock.cc +77 -0
  63. package/vendor/abseil-cpp/absl/base/internal/cycleclock.h +144 -0
  64. package/vendor/abseil-cpp/absl/base/internal/cycleclock_config.h +55 -0
  65. package/vendor/abseil-cpp/absl/base/internal/direct_mmap.h +170 -0
  66. package/vendor/abseil-cpp/absl/base/internal/dynamic_annotations.h +398 -0
  67. package/vendor/abseil-cpp/absl/base/internal/endian.h +282 -0
  68. package/vendor/abseil-cpp/absl/base/internal/endian_test.cc +263 -0
  69. package/vendor/abseil-cpp/absl/base/internal/errno_saver.h +43 -0
  70. package/vendor/abseil-cpp/absl/base/internal/errno_saver_test.cc +45 -0
  71. package/vendor/abseil-cpp/absl/base/internal/exception_safety_testing.cc +79 -0
  72. package/vendor/abseil-cpp/absl/base/internal/exception_safety_testing.h +1109 -0
  73. package/vendor/abseil-cpp/absl/base/internal/exception_testing.h +42 -0
  74. package/vendor/abseil-cpp/absl/base/internal/fast_type_id.h +50 -0
  75. package/vendor/abseil-cpp/absl/base/internal/fast_type_id_test.cc +123 -0
  76. package/vendor/abseil-cpp/absl/base/internal/hide_ptr.h +51 -0
  77. package/vendor/abseil-cpp/absl/base/internal/identity.h +37 -0
  78. package/vendor/abseil-cpp/absl/base/internal/inline_variable.h +107 -0
  79. package/vendor/abseil-cpp/absl/base/internal/inline_variable_testing.h +46 -0
  80. package/vendor/abseil-cpp/absl/base/internal/invoke.h +241 -0
  81. package/vendor/abseil-cpp/absl/base/internal/low_level_alloc.cc +620 -0
  82. package/vendor/abseil-cpp/absl/base/internal/low_level_alloc.h +126 -0
  83. package/vendor/abseil-cpp/absl/base/internal/low_level_alloc_test.cc +180 -0
  84. package/vendor/abseil-cpp/absl/base/internal/low_level_scheduling.h +134 -0
  85. package/vendor/abseil-cpp/absl/base/internal/per_thread_tls.h +52 -0
  86. package/vendor/abseil-cpp/absl/base/internal/prefetch.h +138 -0
  87. package/vendor/abseil-cpp/absl/base/internal/prefetch_test.cc +43 -0
  88. package/vendor/abseil-cpp/absl/base/internal/pretty_function.h +33 -0
  89. package/vendor/abseil-cpp/absl/base/internal/raw_logging.cc +253 -0
  90. package/vendor/abseil-cpp/absl/base/internal/raw_logging.h +195 -0
  91. package/vendor/abseil-cpp/absl/base/internal/scheduling_mode.h +58 -0
  92. package/vendor/abseil-cpp/absl/base/internal/scoped_set_env.cc +81 -0
  93. package/vendor/abseil-cpp/absl/base/internal/scoped_set_env.h +45 -0
  94. package/vendor/abseil-cpp/absl/base/internal/scoped_set_env_test.cc +99 -0
  95. package/vendor/abseil-cpp/absl/base/internal/spinlock.cc +232 -0
  96. package/vendor/abseil-cpp/absl/base/internal/spinlock.h +252 -0
  97. package/vendor/abseil-cpp/absl/base/internal/spinlock_akaros.inc +35 -0
  98. package/vendor/abseil-cpp/absl/base/internal/spinlock_benchmark.cc +52 -0
  99. package/vendor/abseil-cpp/absl/base/internal/spinlock_linux.inc +71 -0
  100. package/vendor/abseil-cpp/absl/base/internal/spinlock_posix.inc +46 -0
  101. package/vendor/abseil-cpp/absl/base/internal/spinlock_wait.cc +81 -0
  102. package/vendor/abseil-cpp/absl/base/internal/spinlock_wait.h +95 -0
  103. package/vendor/abseil-cpp/absl/base/internal/spinlock_win32.inc +40 -0
  104. package/vendor/abseil-cpp/absl/base/internal/strerror.cc +88 -0
  105. package/vendor/abseil-cpp/absl/base/internal/strerror.h +39 -0
  106. package/vendor/abseil-cpp/absl/base/internal/strerror_benchmark.cc +29 -0
  107. package/vendor/abseil-cpp/absl/base/internal/strerror_test.cc +88 -0
  108. package/vendor/abseil-cpp/absl/base/internal/sysinfo.cc +511 -0
  109. package/vendor/abseil-cpp/absl/base/internal/sysinfo.h +74 -0
  110. package/vendor/abseil-cpp/absl/base/internal/sysinfo_test.cc +88 -0
  111. package/vendor/abseil-cpp/absl/base/internal/thread_annotations.h +280 -0
  112. package/vendor/abseil-cpp/absl/base/internal/thread_identity.cc +156 -0
  113. package/vendor/abseil-cpp/absl/base/internal/thread_identity.h +269 -0
  114. package/vendor/abseil-cpp/absl/base/internal/thread_identity_benchmark.cc +38 -0
  115. package/vendor/abseil-cpp/absl/base/internal/thread_identity_test.cc +129 -0
  116. package/vendor/abseil-cpp/absl/base/internal/throw_delegate.cc +212 -0
  117. package/vendor/abseil-cpp/absl/base/internal/throw_delegate.h +75 -0
  118. package/vendor/abseil-cpp/absl/base/internal/tsan_mutex_interface.h +68 -0
  119. package/vendor/abseil-cpp/absl/base/internal/unaligned_access.h +82 -0
  120. package/vendor/abseil-cpp/absl/base/internal/unique_small_name_test.cc +77 -0
  121. package/vendor/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +153 -0
  122. package/vendor/abseil-cpp/absl/base/internal/unscaledcycleclock.h +96 -0
  123. package/vendor/abseil-cpp/absl/base/internal/unscaledcycleclock_config.h +62 -0
  124. package/vendor/abseil-cpp/absl/base/invoke_test.cc +331 -0
  125. package/vendor/abseil-cpp/absl/base/log_severity.cc +55 -0
  126. package/vendor/abseil-cpp/absl/base/log_severity.h +172 -0
  127. package/vendor/abseil-cpp/absl/base/log_severity_test.cc +245 -0
  128. package/vendor/abseil-cpp/absl/base/macros.h +141 -0
  129. package/vendor/abseil-cpp/absl/base/optimization.h +304 -0
  130. package/vendor/abseil-cpp/absl/base/optimization_test.cc +129 -0
  131. package/vendor/abseil-cpp/absl/base/options.h +232 -0
  132. package/vendor/abseil-cpp/absl/base/policy_checks.h +113 -0
  133. package/vendor/abseil-cpp/absl/base/port.h +25 -0
  134. package/vendor/abseil-cpp/absl/base/raw_logging_test.cc +79 -0
  135. package/vendor/abseil-cpp/absl/base/spinlock_test_common.cc +272 -0
  136. package/vendor/abseil-cpp/absl/base/thread_annotations.h +335 -0
  137. package/vendor/abseil-cpp/absl/base/throw_delegate_test.cc +175 -0
  138. package/vendor/abseil-cpp/absl/cleanup/BUILD.bazel +65 -0
  139. package/vendor/abseil-cpp/absl/cleanup/CMakeLists.txt +56 -0
  140. package/vendor/abseil-cpp/absl/cleanup/cleanup.h +140 -0
  141. package/vendor/abseil-cpp/absl/cleanup/cleanup_test.cc +311 -0
  142. package/vendor/abseil-cpp/absl/cleanup/internal/cleanup.h +100 -0
  143. package/vendor/abseil-cpp/absl/container/BUILD.bazel +1031 -0
  144. package/vendor/abseil-cpp/absl/container/CMakeLists.txt +967 -0
  145. package/vendor/abseil-cpp/absl/container/btree_benchmark.cc +764 -0
  146. package/vendor/abseil-cpp/absl/container/btree_map.h +885 -0
  147. package/vendor/abseil-cpp/absl/container/btree_set.h +821 -0
  148. package/vendor/abseil-cpp/absl/container/btree_test.cc +3470 -0
  149. package/vendor/abseil-cpp/absl/container/btree_test.h +166 -0
  150. package/vendor/abseil-cpp/absl/container/fixed_array.h +531 -0
  151. package/vendor/abseil-cpp/absl/container/fixed_array_benchmark.cc +67 -0
  152. package/vendor/abseil-cpp/absl/container/fixed_array_exception_safety_test.cc +201 -0
  153. package/vendor/abseil-cpp/absl/container/fixed_array_test.cc +837 -0
  154. package/vendor/abseil-cpp/absl/container/flat_hash_map.h +613 -0
  155. package/vendor/abseil-cpp/absl/container/flat_hash_map_test.cc +325 -0
  156. package/vendor/abseil-cpp/absl/container/flat_hash_set.h +503 -0
  157. package/vendor/abseil-cpp/absl/container/flat_hash_set_test.cc +178 -0
  158. package/vendor/abseil-cpp/absl/container/inlined_vector.h +914 -0
  159. package/vendor/abseil-cpp/absl/container/inlined_vector_benchmark.cc +829 -0
  160. package/vendor/abseil-cpp/absl/container/inlined_vector_exception_safety_test.cc +508 -0
  161. package/vendor/abseil-cpp/absl/container/inlined_vector_test.cc +2060 -0
  162. package/vendor/abseil-cpp/absl/container/internal/btree.h +2982 -0
  163. package/vendor/abseil-cpp/absl/container/internal/btree_container.h +713 -0
  164. package/vendor/abseil-cpp/absl/container/internal/common.h +207 -0
  165. package/vendor/abseil-cpp/absl/container/internal/common_policy_traits.h +132 -0
  166. package/vendor/abseil-cpp/absl/container/internal/common_policy_traits_test.cc +120 -0
  167. package/vendor/abseil-cpp/absl/container/internal/compressed_tuple.h +290 -0
  168. package/vendor/abseil-cpp/absl/container/internal/compressed_tuple_test.cc +419 -0
  169. package/vendor/abseil-cpp/absl/container/internal/container_memory.h +454 -0
  170. package/vendor/abseil-cpp/absl/container/internal/container_memory_test.cc +257 -0
  171. package/vendor/abseil-cpp/absl/container/internal/counting_allocator.h +122 -0
  172. package/vendor/abseil-cpp/absl/container/internal/hash_function_defaults.h +163 -0
  173. package/vendor/abseil-cpp/absl/container/internal/hash_function_defaults_test.cc +383 -0
  174. package/vendor/abseil-cpp/absl/container/internal/hash_generator_testing.cc +76 -0
  175. package/vendor/abseil-cpp/absl/container/internal/hash_generator_testing.h +182 -0
  176. package/vendor/abseil-cpp/absl/container/internal/hash_policy_testing.h +184 -0
  177. package/vendor/abseil-cpp/absl/container/internal/hash_policy_testing_test.cc +45 -0
  178. package/vendor/abseil-cpp/absl/container/internal/hash_policy_traits.h +157 -0
  179. package/vendor/abseil-cpp/absl/container/internal/hash_policy_traits_test.cc +80 -0
  180. package/vendor/abseil-cpp/absl/container/internal/hashtable_debug.h +110 -0
  181. package/vendor/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +85 -0
  182. package/vendor/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +283 -0
  183. package/vendor/abseil-cpp/absl/container/internal/hashtablez_sampler.h +267 -0
  184. package/vendor/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +31 -0
  185. package/vendor/abseil-cpp/absl/container/internal/hashtablez_sampler_test.cc +428 -0
  186. package/vendor/abseil-cpp/absl/container/internal/inlined_vector.h +1031 -0
  187. package/vendor/abseil-cpp/absl/container/internal/layout.h +743 -0
  188. package/vendor/abseil-cpp/absl/container/internal/layout_benchmark.cc +122 -0
  189. package/vendor/abseil-cpp/absl/container/internal/layout_test.cc +1641 -0
  190. package/vendor/abseil-cpp/absl/container/internal/node_slot_policy.h +92 -0
  191. package/vendor/abseil-cpp/absl/container/internal/node_slot_policy_test.cc +69 -0
  192. package/vendor/abseil-cpp/absl/container/internal/raw_hash_map.h +198 -0
  193. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set.cc +222 -0
  194. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set.h +2685 -0
  195. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_allocator_test.cc +505 -0
  196. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_benchmark.cc +544 -0
  197. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_probe_benchmark.cc +590 -0
  198. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_test.cc +2324 -0
  199. package/vendor/abseil-cpp/absl/container/internal/test_instance_tracker.cc +29 -0
  200. package/vendor/abseil-cpp/absl/container/internal/test_instance_tracker.h +274 -0
  201. package/vendor/abseil-cpp/absl/container/internal/test_instance_tracker_test.cc +184 -0
  202. package/vendor/abseil-cpp/absl/container/internal/tracked.h +83 -0
  203. package/vendor/abseil-cpp/absl/container/internal/unordered_map_constructor_test.h +494 -0
  204. package/vendor/abseil-cpp/absl/container/internal/unordered_map_lookup_test.h +117 -0
  205. package/vendor/abseil-cpp/absl/container/internal/unordered_map_members_test.h +87 -0
  206. package/vendor/abseil-cpp/absl/container/internal/unordered_map_modifiers_test.h +352 -0
  207. package/vendor/abseil-cpp/absl/container/internal/unordered_map_test.cc +50 -0
  208. package/vendor/abseil-cpp/absl/container/internal/unordered_set_constructor_test.h +496 -0
  209. package/vendor/abseil-cpp/absl/container/internal/unordered_set_lookup_test.h +91 -0
  210. package/vendor/abseil-cpp/absl/container/internal/unordered_set_members_test.h +86 -0
  211. package/vendor/abseil-cpp/absl/container/internal/unordered_set_modifiers_test.h +221 -0
  212. package/vendor/abseil-cpp/absl/container/internal/unordered_set_test.cc +41 -0
  213. package/vendor/abseil-cpp/absl/container/node_hash_map.h +604 -0
  214. package/vendor/abseil-cpp/absl/container/node_hash_map_test.cc +286 -0
  215. package/vendor/abseil-cpp/absl/container/node_hash_set.h +500 -0
  216. package/vendor/abseil-cpp/absl/container/node_hash_set_test.cc +143 -0
  217. package/vendor/abseil-cpp/absl/container/sample_element_size_test.cc +114 -0
  218. package/vendor/abseil-cpp/absl/copts/AbseilConfigureCopts.cmake +96 -0
  219. package/vendor/abseil-cpp/absl/copts/GENERATED_AbseilCopts.cmake +229 -0
  220. package/vendor/abseil-cpp/absl/copts/GENERATED_copts.bzl +230 -0
  221. package/vendor/abseil-cpp/absl/copts/configure_copts.bzl +82 -0
  222. package/vendor/abseil-cpp/absl/copts/copts.py +191 -0
  223. package/vendor/abseil-cpp/absl/copts/generate_copts.py +109 -0
  224. package/vendor/abseil-cpp/absl/crc/BUILD.bazel +210 -0
  225. package/vendor/abseil-cpp/absl/crc/CMakeLists.txt +176 -0
  226. package/vendor/abseil-cpp/absl/crc/crc32c.cc +99 -0
  227. package/vendor/abseil-cpp/absl/crc/crc32c.h +183 -0
  228. package/vendor/abseil-cpp/absl/crc/crc32c_benchmark.cc +183 -0
  229. package/vendor/abseil-cpp/absl/crc/crc32c_test.cc +194 -0
  230. package/vendor/abseil-cpp/absl/crc/internal/cpu_detect.cc +256 -0
  231. package/vendor/abseil-cpp/absl/crc/internal/cpu_detect.h +57 -0
  232. package/vendor/abseil-cpp/absl/crc/internal/crc.cc +468 -0
  233. package/vendor/abseil-cpp/absl/crc/internal/crc.h +91 -0
  234. package/vendor/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +269 -0
  235. package/vendor/abseil-cpp/absl/crc/internal/crc32c.h +39 -0
  236. package/vendor/abseil-cpp/absl/crc/internal/crc32c_inline.h +72 -0
  237. package/vendor/abseil-cpp/absl/crc/internal/crc_cord_state.cc +130 -0
  238. package/vendor/abseil-cpp/absl/crc/internal/crc_cord_state.h +159 -0
  239. package/vendor/abseil-cpp/absl/crc/internal/crc_cord_state_test.cc +124 -0
  240. package/vendor/abseil-cpp/absl/crc/internal/crc_internal.h +179 -0
  241. package/vendor/abseil-cpp/absl/crc/internal/crc_memcpy.h +119 -0
  242. package/vendor/abseil-cpp/absl/crc/internal/crc_memcpy_fallback.cc +75 -0
  243. package/vendor/abseil-cpp/absl/crc/internal/crc_memcpy_test.cc +169 -0
  244. package/vendor/abseil-cpp/absl/crc/internal/crc_memcpy_x86_64.cc +434 -0
  245. package/vendor/abseil-cpp/absl/crc/internal/crc_non_temporal_memcpy.cc +93 -0
  246. package/vendor/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +725 -0
  247. package/vendor/abseil-cpp/absl/crc/internal/non_temporal_arm_intrinsics.h +79 -0
  248. package/vendor/abseil-cpp/absl/crc/internal/non_temporal_memcpy.h +180 -0
  249. package/vendor/abseil-cpp/absl/crc/internal/non_temporal_memcpy_test.cc +88 -0
  250. package/vendor/abseil-cpp/absl/debugging/BUILD.bazel +322 -0
  251. package/vendor/abseil-cpp/absl/debugging/CMakeLists.txt +294 -0
  252. package/vendor/abseil-cpp/absl/debugging/failure_signal_handler.cc +389 -0
  253. package/vendor/abseil-cpp/absl/debugging/failure_signal_handler.h +121 -0
  254. package/vendor/abseil-cpp/absl/debugging/failure_signal_handler_test.cc +165 -0
  255. package/vendor/abseil-cpp/absl/debugging/internal/address_is_readable.cc +96 -0
  256. package/vendor/abseil-cpp/absl/debugging/internal/address_is_readable.h +32 -0
  257. package/vendor/abseil-cpp/absl/debugging/internal/demangle.cc +1988 -0
  258. package/vendor/abseil-cpp/absl/debugging/internal/demangle.h +71 -0
  259. package/vendor/abseil-cpp/absl/debugging/internal/demangle_test.cc +243 -0
  260. package/vendor/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +386 -0
  261. package/vendor/abseil-cpp/absl/debugging/internal/elf_mem_image.h +139 -0
  262. package/vendor/abseil-cpp/absl/debugging/internal/examine_stack.cc +317 -0
  263. package/vendor/abseil-cpp/absl/debugging/internal/examine_stack.h +64 -0
  264. package/vendor/abseil-cpp/absl/debugging/internal/stack_consumption.cc +185 -0
  265. package/vendor/abseil-cpp/absl/debugging/internal/stack_consumption.h +50 -0
  266. package/vendor/abseil-cpp/absl/debugging/internal/stack_consumption_test.cc +50 -0
  267. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +206 -0
  268. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +139 -0
  269. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_config.h +88 -0
  270. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_emscripten-inl.inc +110 -0
  271. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +108 -0
  272. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +258 -0
  273. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +191 -0
  274. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +24 -0
  275. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +94 -0
  276. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +394 -0
  277. package/vendor/abseil-cpp/absl/debugging/internal/symbolize.h +153 -0
  278. package/vendor/abseil-cpp/absl/debugging/internal/vdso_support.cc +205 -0
  279. package/vendor/abseil-cpp/absl/debugging/internal/vdso_support.h +158 -0
  280. package/vendor/abseil-cpp/absl/debugging/leak_check.cc +73 -0
  281. package/vendor/abseil-cpp/absl/debugging/leak_check.h +150 -0
  282. package/vendor/abseil-cpp/absl/debugging/leak_check_fail_test.cc +41 -0
  283. package/vendor/abseil-cpp/absl/debugging/leak_check_test.cc +41 -0
  284. package/vendor/abseil-cpp/absl/debugging/stacktrace.cc +142 -0
  285. package/vendor/abseil-cpp/absl/debugging/stacktrace.h +231 -0
  286. package/vendor/abseil-cpp/absl/debugging/stacktrace_benchmark.cc +55 -0
  287. package/vendor/abseil-cpp/absl/debugging/stacktrace_test.cc +47 -0
  288. package/vendor/abseil-cpp/absl/debugging/symbolize.cc +43 -0
  289. package/vendor/abseil-cpp/absl/debugging/symbolize.h +99 -0
  290. package/vendor/abseil-cpp/absl/debugging/symbolize_darwin.inc +102 -0
  291. package/vendor/abseil-cpp/absl/debugging/symbolize_elf.inc +1637 -0
  292. package/vendor/abseil-cpp/absl/debugging/symbolize_emscripten.inc +72 -0
  293. package/vendor/abseil-cpp/absl/debugging/symbolize_test.cc +612 -0
  294. package/vendor/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +40 -0
  295. package/vendor/abseil-cpp/absl/debugging/symbolize_win32.inc +82 -0
  296. package/vendor/abseil-cpp/absl/flags/BUILD.bazel +583 -0
  297. package/vendor/abseil-cpp/absl/flags/CMakeLists.txt +471 -0
  298. package/vendor/abseil-cpp/absl/flags/commandlineflag.cc +34 -0
  299. package/vendor/abseil-cpp/absl/flags/commandlineflag.h +200 -0
  300. package/vendor/abseil-cpp/absl/flags/commandlineflag_test.cc +231 -0
  301. package/vendor/abseil-cpp/absl/flags/config.h +68 -0
  302. package/vendor/abseil-cpp/absl/flags/config_test.cc +61 -0
  303. package/vendor/abseil-cpp/absl/flags/declare.h +73 -0
  304. package/vendor/abseil-cpp/absl/flags/flag.cc +38 -0
  305. package/vendor/abseil-cpp/absl/flags/flag.h +310 -0
  306. package/vendor/abseil-cpp/absl/flags/flag_benchmark.cc +251 -0
  307. package/vendor/abseil-cpp/absl/flags/flag_benchmark.lds +13 -0
  308. package/vendor/abseil-cpp/absl/flags/flag_test.cc +1166 -0
  309. package/vendor/abseil-cpp/absl/flags/flag_test_defs.cc +24 -0
  310. package/vendor/abseil-cpp/absl/flags/internal/commandlineflag.cc +26 -0
  311. package/vendor/abseil-cpp/absl/flags/internal/commandlineflag.h +68 -0
  312. package/vendor/abseil-cpp/absl/flags/internal/flag.cc +615 -0
  313. package/vendor/abseil-cpp/absl/flags/internal/flag.h +800 -0
  314. package/vendor/abseil-cpp/absl/flags/internal/flag_msvc.inc +116 -0
  315. package/vendor/abseil-cpp/absl/flags/internal/parse.h +63 -0
  316. package/vendor/abseil-cpp/absl/flags/internal/path_util.h +62 -0
  317. package/vendor/abseil-cpp/absl/flags/internal/path_util_test.cc +46 -0
  318. package/vendor/abseil-cpp/absl/flags/internal/private_handle_accessor.cc +65 -0
  319. package/vendor/abseil-cpp/absl/flags/internal/private_handle_accessor.h +61 -0
  320. package/vendor/abseil-cpp/absl/flags/internal/program_name.cc +60 -0
  321. package/vendor/abseil-cpp/absl/flags/internal/program_name.h +50 -0
  322. package/vendor/abseil-cpp/absl/flags/internal/program_name_test.cc +61 -0
  323. package/vendor/abseil-cpp/absl/flags/internal/registry.h +97 -0
  324. package/vendor/abseil-cpp/absl/flags/internal/sequence_lock.h +187 -0
  325. package/vendor/abseil-cpp/absl/flags/internal/sequence_lock_test.cc +169 -0
  326. package/vendor/abseil-cpp/absl/flags/internal/usage.cc +526 -0
  327. package/vendor/abseil-cpp/absl/flags/internal/usage.h +104 -0
  328. package/vendor/abseil-cpp/absl/flags/internal/usage_test.cc +504 -0
  329. package/vendor/abseil-cpp/absl/flags/marshalling.cc +241 -0
  330. package/vendor/abseil-cpp/absl/flags/marshalling.h +356 -0
  331. package/vendor/abseil-cpp/absl/flags/marshalling_test.cc +1070 -0
  332. package/vendor/abseil-cpp/absl/flags/parse.cc +890 -0
  333. package/vendor/abseil-cpp/absl/flags/parse.h +60 -0
  334. package/vendor/abseil-cpp/absl/flags/parse_test.cc +1004 -0
  335. package/vendor/abseil-cpp/absl/flags/reflection.cc +354 -0
  336. package/vendor/abseil-cpp/absl/flags/reflection.h +90 -0
  337. package/vendor/abseil-cpp/absl/flags/reflection_test.cc +265 -0
  338. package/vendor/abseil-cpp/absl/flags/usage.cc +65 -0
  339. package/vendor/abseil-cpp/absl/flags/usage.h +43 -0
  340. package/vendor/abseil-cpp/absl/flags/usage_config.cc +165 -0
  341. package/vendor/abseil-cpp/absl/flags/usage_config.h +135 -0
  342. package/vendor/abseil-cpp/absl/flags/usage_config_test.cc +205 -0
  343. package/vendor/abseil-cpp/absl/functional/BUILD.bazel +128 -0
  344. package/vendor/abseil-cpp/absl/functional/CMakeLists.txt +109 -0
  345. package/vendor/abseil-cpp/absl/functional/any_invocable.h +316 -0
  346. package/vendor/abseil-cpp/absl/functional/any_invocable_test.cc +1719 -0
  347. package/vendor/abseil-cpp/absl/functional/bind_front.h +193 -0
  348. package/vendor/abseil-cpp/absl/functional/bind_front_test.cc +231 -0
  349. package/vendor/abseil-cpp/absl/functional/function_ref.h +143 -0
  350. package/vendor/abseil-cpp/absl/functional/function_ref_test.cc +258 -0
  351. package/vendor/abseil-cpp/absl/functional/function_type_benchmark.cc +176 -0
  352. package/vendor/abseil-cpp/absl/functional/internal/any_invocable.h +878 -0
  353. package/vendor/abseil-cpp/absl/functional/internal/front_binder.h +95 -0
  354. package/vendor/abseil-cpp/absl/functional/internal/function_ref.h +106 -0
  355. package/vendor/abseil-cpp/absl/hash/BUILD.bazel +176 -0
  356. package/vendor/abseil-cpp/absl/hash/CMakeLists.txt +160 -0
  357. package/vendor/abseil-cpp/absl/hash/hash.h +421 -0
  358. package/vendor/abseil-cpp/absl/hash/hash_benchmark.cc +323 -0
  359. package/vendor/abseil-cpp/absl/hash/hash_test.cc +1277 -0
  360. package/vendor/abseil-cpp/absl/hash/hash_testing.h +378 -0
  361. package/vendor/abseil-cpp/absl/hash/internal/city.cc +349 -0
  362. package/vendor/abseil-cpp/absl/hash/internal/city.h +78 -0
  363. package/vendor/abseil-cpp/absl/hash/internal/city_test.cc +597 -0
  364. package/vendor/abseil-cpp/absl/hash/internal/hash.cc +69 -0
  365. package/vendor/abseil-cpp/absl/hash/internal/hash.h +1305 -0
  366. package/vendor/abseil-cpp/absl/hash/internal/low_level_hash.cc +112 -0
  367. package/vendor/abseil-cpp/absl/hash/internal/low_level_hash.h +50 -0
  368. package/vendor/abseil-cpp/absl/hash/internal/low_level_hash_test.cc +532 -0
  369. package/vendor/abseil-cpp/absl/hash/internal/print_hash_of.cc +23 -0
  370. package/vendor/abseil-cpp/absl/hash/internal/spy_hash_state.h +266 -0
  371. package/vendor/abseil-cpp/absl/log/BUILD.bazel +596 -0
  372. package/vendor/abseil-cpp/absl/log/CMakeLists.txt +1042 -0
  373. package/vendor/abseil-cpp/absl/log/absl_check.h +105 -0
  374. package/vendor/abseil-cpp/absl/log/absl_check_test.cc +58 -0
  375. package/vendor/abseil-cpp/absl/log/absl_log.h +94 -0
  376. package/vendor/abseil-cpp/absl/log/absl_log_basic_test.cc +21 -0
  377. package/vendor/abseil-cpp/absl/log/check.h +183 -0
  378. package/vendor/abseil-cpp/absl/log/check_test.cc +58 -0
  379. package/vendor/abseil-cpp/absl/log/check_test_impl.h +528 -0
  380. package/vendor/abseil-cpp/absl/log/die_if_null.cc +32 -0
  381. package/vendor/abseil-cpp/absl/log/die_if_null.h +76 -0
  382. package/vendor/abseil-cpp/absl/log/die_if_null_test.cc +107 -0
  383. package/vendor/abseil-cpp/absl/log/flags.cc +112 -0
  384. package/vendor/abseil-cpp/absl/log/flags.h +43 -0
  385. package/vendor/abseil-cpp/absl/log/flags_test.cc +184 -0
  386. package/vendor/abseil-cpp/absl/log/globals.cc +148 -0
  387. package/vendor/abseil-cpp/absl/log/globals.h +165 -0
  388. package/vendor/abseil-cpp/absl/log/globals_test.cc +91 -0
  389. package/vendor/abseil-cpp/absl/log/initialize.cc +34 -0
  390. package/vendor/abseil-cpp/absl/log/initialize.h +45 -0
  391. package/vendor/abseil-cpp/absl/log/internal/BUILD.bazel +383 -0
  392. package/vendor/abseil-cpp/absl/log/internal/append_truncated.h +47 -0
  393. package/vendor/abseil-cpp/absl/log/internal/check_impl.h +150 -0
  394. package/vendor/abseil-cpp/absl/log/internal/check_op.cc +118 -0
  395. package/vendor/abseil-cpp/absl/log/internal/check_op.h +392 -0
  396. package/vendor/abseil-cpp/absl/log/internal/conditions.cc +83 -0
  397. package/vendor/abseil-cpp/absl/log/internal/conditions.h +222 -0
  398. package/vendor/abseil-cpp/absl/log/internal/config.h +45 -0
  399. package/vendor/abseil-cpp/absl/log/internal/flags.h +53 -0
  400. package/vendor/abseil-cpp/absl/log/internal/globals.cc +125 -0
  401. package/vendor/abseil-cpp/absl/log/internal/globals.h +101 -0
  402. package/vendor/abseil-cpp/absl/log/internal/log_format.cc +203 -0
  403. package/vendor/abseil-cpp/absl/log/internal/log_format.h +78 -0
  404. package/vendor/abseil-cpp/absl/log/internal/log_impl.h +212 -0
  405. package/vendor/abseil-cpp/absl/log/internal/log_message.cc +618 -0
  406. package/vendor/abseil-cpp/absl/log/internal/log_message.h +355 -0
  407. package/vendor/abseil-cpp/absl/log/internal/log_sink_set.cc +296 -0
  408. package/vendor/abseil-cpp/absl/log/internal/log_sink_set.h +54 -0
  409. package/vendor/abseil-cpp/absl/log/internal/nullguard.cc +35 -0
  410. package/vendor/abseil-cpp/absl/log/internal/nullguard.h +88 -0
  411. package/vendor/abseil-cpp/absl/log/internal/nullstream.h +134 -0
  412. package/vendor/abseil-cpp/absl/log/internal/proto.cc +220 -0
  413. package/vendor/abseil-cpp/absl/log/internal/proto.h +288 -0
  414. package/vendor/abseil-cpp/absl/log/internal/stderr_log_sink_test.cc +105 -0
  415. package/vendor/abseil-cpp/absl/log/internal/strip.h +71 -0
  416. package/vendor/abseil-cpp/absl/log/internal/structured.h +58 -0
  417. package/vendor/abseil-cpp/absl/log/internal/test_actions.cc +75 -0
  418. package/vendor/abseil-cpp/absl/log/internal/test_actions.h +90 -0
  419. package/vendor/abseil-cpp/absl/log/internal/test_helpers.cc +82 -0
  420. package/vendor/abseil-cpp/absl/log/internal/test_helpers.h +71 -0
  421. package/vendor/abseil-cpp/absl/log/internal/test_matchers.cc +217 -0
  422. package/vendor/abseil-cpp/absl/log/internal/test_matchers.h +94 -0
  423. package/vendor/abseil-cpp/absl/log/internal/voidify.h +44 -0
  424. package/vendor/abseil-cpp/absl/log/log.h +308 -0
  425. package/vendor/abseil-cpp/absl/log/log_basic_test.cc +21 -0
  426. package/vendor/abseil-cpp/absl/log/log_basic_test_impl.h +455 -0
  427. package/vendor/abseil-cpp/absl/log/log_benchmark.cc +97 -0
  428. package/vendor/abseil-cpp/absl/log/log_entry.cc +29 -0
  429. package/vendor/abseil-cpp/absl/log/log_entry.h +220 -0
  430. package/vendor/abseil-cpp/absl/log/log_entry_test.cc +468 -0
  431. package/vendor/abseil-cpp/absl/log/log_format_test.cc +1872 -0
  432. package/vendor/abseil-cpp/absl/log/log_macro_hygiene_test.cc +187 -0
  433. package/vendor/abseil-cpp/absl/log/log_modifier_methods_test.cc +233 -0
  434. package/vendor/abseil-cpp/absl/log/log_sink.cc +23 -0
  435. package/vendor/abseil-cpp/absl/log/log_sink.h +64 -0
  436. package/vendor/abseil-cpp/absl/log/log_sink_registry.h +61 -0
  437. package/vendor/abseil-cpp/absl/log/log_sink_test.cc +419 -0
  438. package/vendor/abseil-cpp/absl/log/log_streamer.h +171 -0
  439. package/vendor/abseil-cpp/absl/log/log_streamer_test.cc +365 -0
  440. package/vendor/abseil-cpp/absl/log/scoped_mock_log.cc +86 -0
  441. package/vendor/abseil-cpp/absl/log/scoped_mock_log.h +194 -0
  442. package/vendor/abseil-cpp/absl/log/scoped_mock_log_test.cc +290 -0
  443. package/vendor/abseil-cpp/absl/log/stripping_test.cc +340 -0
  444. package/vendor/abseil-cpp/absl/log/structured.h +70 -0
  445. package/vendor/abseil-cpp/absl/log/structured_test.cc +63 -0
  446. package/vendor/abseil-cpp/absl/memory/BUILD.bazel +52 -0
  447. package/vendor/abseil-cpp/absl/memory/CMakeLists.txt +41 -0
  448. package/vendor/abseil-cpp/absl/memory/memory.h +278 -0
  449. package/vendor/abseil-cpp/absl/memory/memory_test.cc +222 -0
  450. package/vendor/abseil-cpp/absl/meta/BUILD.bazel +50 -0
  451. package/vendor/abseil-cpp/absl/meta/CMakeLists.txt +53 -0
  452. package/vendor/abseil-cpp/absl/meta/type_traits.h +889 -0
  453. package/vendor/abseil-cpp/absl/meta/type_traits_test.cc +1448 -0
  454. package/vendor/abseil-cpp/absl/numeric/BUILD.bazel +127 -0
  455. package/vendor/abseil-cpp/absl/numeric/CMakeLists.txt +99 -0
  456. package/vendor/abseil-cpp/absl/numeric/bits.h +177 -0
  457. package/vendor/abseil-cpp/absl/numeric/bits_benchmark.cc +73 -0
  458. package/vendor/abseil-cpp/absl/numeric/bits_test.cc +573 -0
  459. package/vendor/abseil-cpp/absl/numeric/int128.cc +387 -0
  460. package/vendor/abseil-cpp/absl/numeric/int128.h +1165 -0
  461. package/vendor/abseil-cpp/absl/numeric/int128_benchmark.cc +282 -0
  462. package/vendor/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +296 -0
  463. package/vendor/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +311 -0
  464. package/vendor/abseil-cpp/absl/numeric/int128_stream_test.cc +1393 -0
  465. package/vendor/abseil-cpp/absl/numeric/int128_test.cc +1261 -0
  466. package/vendor/abseil-cpp/absl/numeric/internal/bits.h +358 -0
  467. package/vendor/abseil-cpp/absl/numeric/internal/representation.h +55 -0
  468. package/vendor/abseil-cpp/absl/profiling/BUILD.bazel +129 -0
  469. package/vendor/abseil-cpp/absl/profiling/CMakeLists.txt +93 -0
  470. package/vendor/abseil-cpp/absl/profiling/internal/exponential_biased.cc +93 -0
  471. package/vendor/abseil-cpp/absl/profiling/internal/exponential_biased.h +130 -0
  472. package/vendor/abseil-cpp/absl/profiling/internal/exponential_biased_test.cc +203 -0
  473. package/vendor/abseil-cpp/absl/profiling/internal/periodic_sampler.cc +53 -0
  474. package/vendor/abseil-cpp/absl/profiling/internal/periodic_sampler.h +211 -0
  475. package/vendor/abseil-cpp/absl/profiling/internal/periodic_sampler_benchmark.cc +79 -0
  476. package/vendor/abseil-cpp/absl/profiling/internal/periodic_sampler_test.cc +177 -0
  477. package/vendor/abseil-cpp/absl/profiling/internal/sample_recorder.h +253 -0
  478. package/vendor/abseil-cpp/absl/profiling/internal/sample_recorder_test.cc +184 -0
  479. package/vendor/abseil-cpp/absl/random/BUILD.bazel +517 -0
  480. package/vendor/abseil-cpp/absl/random/CMakeLists.txt +1216 -0
  481. package/vendor/abseil-cpp/absl/random/benchmarks.cc +383 -0
  482. package/vendor/abseil-cpp/absl/random/bernoulli_distribution.h +200 -0
  483. package/vendor/abseil-cpp/absl/random/bernoulli_distribution_test.cc +217 -0
  484. package/vendor/abseil-cpp/absl/random/beta_distribution.h +427 -0
  485. package/vendor/abseil-cpp/absl/random/beta_distribution_test.cc +620 -0
  486. package/vendor/abseil-cpp/absl/random/bit_gen_ref.h +185 -0
  487. package/vendor/abseil-cpp/absl/random/bit_gen_ref_test.cc +102 -0
  488. package/vendor/abseil-cpp/absl/random/discrete_distribution.cc +98 -0
  489. package/vendor/abseil-cpp/absl/random/discrete_distribution.h +247 -0
  490. package/vendor/abseil-cpp/absl/random/discrete_distribution_test.cc +251 -0
  491. package/vendor/abseil-cpp/absl/random/distributions.h +452 -0
  492. package/vendor/abseil-cpp/absl/random/distributions_test.cc +466 -0
  493. package/vendor/abseil-cpp/absl/random/examples_test.cc +99 -0
  494. package/vendor/abseil-cpp/absl/random/exponential_distribution.h +165 -0
  495. package/vendor/abseil-cpp/absl/random/exponential_distribution_test.cc +428 -0
  496. package/vendor/abseil-cpp/absl/random/gaussian_distribution.cc +104 -0
  497. package/vendor/abseil-cpp/absl/random/gaussian_distribution.h +275 -0
  498. package/vendor/abseil-cpp/absl/random/gaussian_distribution_test.cc +563 -0
  499. package/vendor/abseil-cpp/absl/random/generators_test.cc +185 -0
  500. package/vendor/abseil-cpp/absl/random/internal/BUILD.bazel +753 -0
  501. package/vendor/abseil-cpp/absl/random/internal/chi_square.cc +233 -0
  502. package/vendor/abseil-cpp/absl/random/internal/chi_square.h +89 -0
  503. package/vendor/abseil-cpp/absl/random/internal/chi_square_test.cc +365 -0
  504. package/vendor/abseil-cpp/absl/random/internal/distribution_caller.h +95 -0
  505. package/vendor/abseil-cpp/absl/random/internal/distribution_test_util.cc +418 -0
  506. package/vendor/abseil-cpp/absl/random/internal/distribution_test_util.h +113 -0
  507. package/vendor/abseil-cpp/absl/random/internal/distribution_test_util_test.cc +193 -0
  508. package/vendor/abseil-cpp/absl/random/internal/explicit_seed_seq.h +92 -0
  509. package/vendor/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc +237 -0
  510. package/vendor/abseil-cpp/absl/random/internal/fast_uniform_bits.h +270 -0
  511. package/vendor/abseil-cpp/absl/random/internal/fast_uniform_bits_test.cc +336 -0
  512. package/vendor/abseil-cpp/absl/random/internal/fastmath.h +57 -0
  513. package/vendor/abseil-cpp/absl/random/internal/fastmath_test.cc +97 -0
  514. package/vendor/abseil-cpp/absl/random/internal/gaussian_distribution_gentables.cc +143 -0
  515. package/vendor/abseil-cpp/absl/random/internal/generate_real.h +144 -0
  516. package/vendor/abseil-cpp/absl/random/internal/generate_real_test.cc +496 -0
  517. package/vendor/abseil-cpp/absl/random/internal/iostream_state_saver.h +245 -0
  518. package/vendor/abseil-cpp/absl/random/internal/iostream_state_saver_test.cc +372 -0
  519. package/vendor/abseil-cpp/absl/random/internal/mock_helpers.h +135 -0
  520. package/vendor/abseil-cpp/absl/random/internal/mock_overload_set.h +100 -0
  521. package/vendor/abseil-cpp/absl/random/internal/nanobenchmark.cc +804 -0
  522. package/vendor/abseil-cpp/absl/random/internal/nanobenchmark.h +172 -0
  523. package/vendor/abseil-cpp/absl/random/internal/nanobenchmark_test.cc +77 -0
  524. package/vendor/abseil-cpp/absl/random/internal/nonsecure_base.h +161 -0
  525. package/vendor/abseil-cpp/absl/random/internal/nonsecure_base_test.cc +227 -0
  526. package/vendor/abseil-cpp/absl/random/internal/pcg_engine.h +287 -0
  527. package/vendor/abseil-cpp/absl/random/internal/pcg_engine_test.cc +638 -0
  528. package/vendor/abseil-cpp/absl/random/internal/platform.h +171 -0
  529. package/vendor/abseil-cpp/absl/random/internal/pool_urbg.cc +253 -0
  530. package/vendor/abseil-cpp/absl/random/internal/pool_urbg.h +131 -0
  531. package/vendor/abseil-cpp/absl/random/internal/pool_urbg_test.cc +182 -0
  532. package/vendor/abseil-cpp/absl/random/internal/randen.cc +91 -0
  533. package/vendor/abseil-cpp/absl/random/internal/randen.h +96 -0
  534. package/vendor/abseil-cpp/absl/random/internal/randen_benchmarks.cc +174 -0
  535. package/vendor/abseil-cpp/absl/random/internal/randen_detect.cc +225 -0
  536. package/vendor/abseil-cpp/absl/random/internal/randen_detect.h +33 -0
  537. package/vendor/abseil-cpp/absl/random/internal/randen_engine.h +264 -0
  538. package/vendor/abseil-cpp/absl/random/internal/randen_engine_test.cc +656 -0
  539. package/vendor/abseil-cpp/absl/random/internal/randen_hwaes.cc +526 -0
  540. package/vendor/abseil-cpp/absl/random/internal/randen_hwaes.h +50 -0
  541. package/vendor/abseil-cpp/absl/random/internal/randen_hwaes_test.cc +99 -0
  542. package/vendor/abseil-cpp/absl/random/internal/randen_round_keys.cc +462 -0
  543. package/vendor/abseil-cpp/absl/random/internal/randen_slow.cc +471 -0
  544. package/vendor/abseil-cpp/absl/random/internal/randen_slow.h +40 -0
  545. package/vendor/abseil-cpp/absl/random/internal/randen_slow_test.cc +61 -0
  546. package/vendor/abseil-cpp/absl/random/internal/randen_test.cc +75 -0
  547. package/vendor/abseil-cpp/absl/random/internal/randen_traits.h +88 -0
  548. package/vendor/abseil-cpp/absl/random/internal/salted_seed_seq.h +165 -0
  549. package/vendor/abseil-cpp/absl/random/internal/salted_seed_seq_test.cc +168 -0
  550. package/vendor/abseil-cpp/absl/random/internal/seed_material.cc +267 -0
  551. package/vendor/abseil-cpp/absl/random/internal/seed_material.h +104 -0
  552. package/vendor/abseil-cpp/absl/random/internal/seed_material_test.cc +202 -0
  553. package/vendor/abseil-cpp/absl/random/internal/sequence_urbg.h +60 -0
  554. package/vendor/abseil-cpp/absl/random/internal/traits.h +149 -0
  555. package/vendor/abseil-cpp/absl/random/internal/traits_test.cc +126 -0
  556. package/vendor/abseil-cpp/absl/random/internal/uniform_helper.h +244 -0
  557. package/vendor/abseil-cpp/absl/random/internal/uniform_helper_test.cc +279 -0
  558. package/vendor/abseil-cpp/absl/random/internal/wide_multiply.h +96 -0
  559. package/vendor/abseil-cpp/absl/random/internal/wide_multiply_test.cc +119 -0
  560. package/vendor/abseil-cpp/absl/random/log_uniform_int_distribution.h +256 -0
  561. package/vendor/abseil-cpp/absl/random/log_uniform_int_distribution_test.cc +280 -0
  562. package/vendor/abseil-cpp/absl/random/mock_distributions.h +266 -0
  563. package/vendor/abseil-cpp/absl/random/mock_distributions_test.cc +72 -0
  564. package/vendor/abseil-cpp/absl/random/mocking_bit_gen.h +240 -0
  565. package/vendor/abseil-cpp/absl/random/mocking_bit_gen_test.cc +394 -0
  566. package/vendor/abseil-cpp/absl/random/poisson_distribution.h +261 -0
  567. package/vendor/abseil-cpp/absl/random/poisson_distribution_test.cc +573 -0
  568. package/vendor/abseil-cpp/absl/random/random.h +189 -0
  569. package/vendor/abseil-cpp/absl/random/seed_gen_exception.cc +46 -0
  570. package/vendor/abseil-cpp/absl/random/seed_gen_exception.h +55 -0
  571. package/vendor/abseil-cpp/absl/random/seed_sequences.cc +29 -0
  572. package/vendor/abseil-cpp/absl/random/seed_sequences.h +111 -0
  573. package/vendor/abseil-cpp/absl/random/seed_sequences_test.cc +126 -0
  574. package/vendor/abseil-cpp/absl/random/uniform_int_distribution.h +275 -0
  575. package/vendor/abseil-cpp/absl/random/uniform_int_distribution_test.cc +260 -0
  576. package/vendor/abseil-cpp/absl/random/uniform_real_distribution.h +202 -0
  577. package/vendor/abseil-cpp/absl/random/uniform_real_distribution_test.cc +395 -0
  578. package/vendor/abseil-cpp/absl/random/zipf_distribution.h +272 -0
  579. package/vendor/abseil-cpp/absl/random/zipf_distribution_test.cc +427 -0
  580. package/vendor/abseil-cpp/absl/status/BUILD.bazel +109 -0
  581. package/vendor/abseil-cpp/absl/status/CMakeLists.txt +91 -0
  582. package/vendor/abseil-cpp/absl/status/internal/status_internal.h +87 -0
  583. package/vendor/abseil-cpp/absl/status/internal/statusor_internal.h +396 -0
  584. package/vendor/abseil-cpp/absl/status/status.cc +623 -0
  585. package/vendor/abseil-cpp/absl/status/status.h +892 -0
  586. package/vendor/abseil-cpp/absl/status/status_payload_printer.cc +38 -0
  587. package/vendor/abseil-cpp/absl/status/status_payload_printer.h +51 -0
  588. package/vendor/abseil-cpp/absl/status/status_test.cc +509 -0
  589. package/vendor/abseil-cpp/absl/status/statusor.cc +103 -0
  590. package/vendor/abseil-cpp/absl/status/statusor.h +776 -0
  591. package/vendor/abseil-cpp/absl/status/statusor_test.cc +1847 -0
  592. package/vendor/abseil-cpp/absl/strings/BUILD.bazel +1319 -0
  593. package/vendor/abseil-cpp/absl/strings/CMakeLists.txt +1119 -0
  594. package/vendor/abseil-cpp/absl/strings/ascii.cc +200 -0
  595. package/vendor/abseil-cpp/absl/strings/ascii.h +242 -0
  596. package/vendor/abseil-cpp/absl/strings/ascii_benchmark.cc +120 -0
  597. package/vendor/abseil-cpp/absl/strings/ascii_test.cc +357 -0
  598. package/vendor/abseil-cpp/absl/strings/atod_manual_test.cc +193 -0
  599. package/vendor/abseil-cpp/absl/strings/charconv.cc +1422 -0
  600. package/vendor/abseil-cpp/absl/strings/charconv.h +120 -0
  601. package/vendor/abseil-cpp/absl/strings/charconv_benchmark.cc +204 -0
  602. package/vendor/abseil-cpp/absl/strings/charconv_test.cc +782 -0
  603. package/vendor/abseil-cpp/absl/strings/cord.cc +1380 -0
  604. package/vendor/abseil-cpp/absl/strings/cord.h +1633 -0
  605. package/vendor/abseil-cpp/absl/strings/cord_analysis.cc +188 -0
  606. package/vendor/abseil-cpp/absl/strings/cord_analysis.h +44 -0
  607. package/vendor/abseil-cpp/absl/strings/cord_buffer.cc +30 -0
  608. package/vendor/abseil-cpp/absl/strings/cord_buffer.h +575 -0
  609. package/vendor/abseil-cpp/absl/strings/cord_buffer_test.cc +320 -0
  610. package/vendor/abseil-cpp/absl/strings/cord_ring_reader_test.cc +180 -0
  611. package/vendor/abseil-cpp/absl/strings/cord_ring_test.cc +1454 -0
  612. package/vendor/abseil-cpp/absl/strings/cord_test.cc +3125 -0
  613. package/vendor/abseil-cpp/absl/strings/cord_test_helpers.h +122 -0
  614. package/vendor/abseil-cpp/absl/strings/cordz_test.cc +466 -0
  615. package/vendor/abseil-cpp/absl/strings/cordz_test_helpers.h +151 -0
  616. package/vendor/abseil-cpp/absl/strings/escaping.cc +960 -0
  617. package/vendor/abseil-cpp/absl/strings/escaping.h +169 -0
  618. package/vendor/abseil-cpp/absl/strings/escaping_benchmark.cc +94 -0
  619. package/vendor/abseil-cpp/absl/strings/escaping_test.cc +706 -0
  620. package/vendor/abseil-cpp/absl/strings/internal/char_map.h +158 -0
  621. package/vendor/abseil-cpp/absl/strings/internal/char_map_benchmark.cc +61 -0
  622. package/vendor/abseil-cpp/absl/strings/internal/char_map_test.cc +172 -0
  623. package/vendor/abseil-cpp/absl/strings/internal/charconv_bigint.cc +359 -0
  624. package/vendor/abseil-cpp/absl/strings/internal/charconv_bigint.h +423 -0
  625. package/vendor/abseil-cpp/absl/strings/internal/charconv_bigint_test.cc +260 -0
  626. package/vendor/abseil-cpp/absl/strings/internal/charconv_parse.cc +504 -0
  627. package/vendor/abseil-cpp/absl/strings/internal/charconv_parse.h +99 -0
  628. package/vendor/abseil-cpp/absl/strings/internal/charconv_parse_test.cc +357 -0
  629. package/vendor/abseil-cpp/absl/strings/internal/cord_data_edge.h +63 -0
  630. package/vendor/abseil-cpp/absl/strings/internal/cord_data_edge_test.cc +130 -0
  631. package/vendor/abseil-cpp/absl/strings/internal/cord_internal.cc +77 -0
  632. package/vendor/abseil-cpp/absl/strings/internal/cord_internal.h +915 -0
  633. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +1232 -0
  634. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree.h +936 -0
  635. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +187 -0
  636. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +267 -0
  637. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator_test.cc +346 -0
  638. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +69 -0
  639. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +212 -0
  640. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree_reader_test.cc +293 -0
  641. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree_test.cc +1568 -0
  642. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +62 -0
  643. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_consume.h +50 -0
  644. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +56 -0
  645. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_crc.h +103 -0
  646. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_crc_test.cc +130 -0
  647. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_flat.h +187 -0
  648. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +773 -0
  649. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_ring.h +607 -0
  650. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_ring_reader.h +118 -0
  651. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_test_util.h +205 -0
  652. package/vendor/abseil-cpp/absl/strings/internal/cordz_functions.cc +96 -0
  653. package/vendor/abseil-cpp/absl/strings/internal/cordz_functions.h +77 -0
  654. package/vendor/abseil-cpp/absl/strings/internal/cordz_functions_test.cc +149 -0
  655. package/vendor/abseil-cpp/absl/strings/internal/cordz_handle.cc +139 -0
  656. package/vendor/abseil-cpp/absl/strings/internal/cordz_handle.h +131 -0
  657. package/vendor/abseil-cpp/absl/strings/internal/cordz_handle_test.cc +265 -0
  658. package/vendor/abseil-cpp/absl/strings/internal/cordz_info.cc +421 -0
  659. package/vendor/abseil-cpp/absl/strings/internal/cordz_info.h +298 -0
  660. package/vendor/abseil-cpp/absl/strings/internal/cordz_info_statistics_test.cc +557 -0
  661. package/vendor/abseil-cpp/absl/strings/internal/cordz_info_test.cc +342 -0
  662. package/vendor/abseil-cpp/absl/strings/internal/cordz_sample_token.cc +64 -0
  663. package/vendor/abseil-cpp/absl/strings/internal/cordz_sample_token.h +97 -0
  664. package/vendor/abseil-cpp/absl/strings/internal/cordz_sample_token_test.cc +208 -0
  665. package/vendor/abseil-cpp/absl/strings/internal/cordz_statistics.h +88 -0
  666. package/vendor/abseil-cpp/absl/strings/internal/cordz_update_scope.h +71 -0
  667. package/vendor/abseil-cpp/absl/strings/internal/cordz_update_scope_test.cc +49 -0
  668. package/vendor/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +123 -0
  669. package/vendor/abseil-cpp/absl/strings/internal/cordz_update_tracker_test.cc +147 -0
  670. package/vendor/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance.cc +93 -0
  671. package/vendor/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance.h +34 -0
  672. package/vendor/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance_test.cc +99 -0
  673. package/vendor/abseil-cpp/absl/strings/internal/escaping.cc +183 -0
  674. package/vendor/abseil-cpp/absl/strings/internal/escaping.h +56 -0
  675. package/vendor/abseil-cpp/absl/strings/internal/escaping_test_common.h +133 -0
  676. package/vendor/abseil-cpp/absl/strings/internal/has_absl_stringify.h +55 -0
  677. package/vendor/abseil-cpp/absl/strings/internal/memutil.cc +115 -0
  678. package/vendor/abseil-cpp/absl/strings/internal/memutil.h +148 -0
  679. package/vendor/abseil-cpp/absl/strings/internal/memutil_benchmark.cc +323 -0
  680. package/vendor/abseil-cpp/absl/strings/internal/memutil_test.cc +179 -0
  681. package/vendor/abseil-cpp/absl/strings/internal/numbers_test_common.h +184 -0
  682. package/vendor/abseil-cpp/absl/strings/internal/ostringstream.cc +43 -0
  683. package/vendor/abseil-cpp/absl/strings/internal/ostringstream.h +114 -0
  684. package/vendor/abseil-cpp/absl/strings/internal/ostringstream_benchmark.cc +106 -0
  685. package/vendor/abseil-cpp/absl/strings/internal/ostringstream_test.cc +131 -0
  686. package/vendor/abseil-cpp/absl/strings/internal/pow10_helper.cc +122 -0
  687. package/vendor/abseil-cpp/absl/strings/internal/pow10_helper.h +40 -0
  688. package/vendor/abseil-cpp/absl/strings/internal/pow10_helper_test.cc +122 -0
  689. package/vendor/abseil-cpp/absl/strings/internal/resize_uninitialized.h +119 -0
  690. package/vendor/abseil-cpp/absl/strings/internal/resize_uninitialized_test.cc +133 -0
  691. package/vendor/abseil-cpp/absl/strings/internal/stl_type_traits.h +248 -0
  692. package/vendor/abseil-cpp/absl/strings/internal/str_format/arg.cc +555 -0
  693. package/vendor/abseil-cpp/absl/strings/internal/str_format/arg.h +623 -0
  694. package/vendor/abseil-cpp/absl/strings/internal/str_format/arg_test.cc +130 -0
  695. package/vendor/abseil-cpp/absl/strings/internal/str_format/bind.cc +259 -0
  696. package/vendor/abseil-cpp/absl/strings/internal/str_format/bind.h +249 -0
  697. package/vendor/abseil-cpp/absl/strings/internal/str_format/bind_test.cc +157 -0
  698. package/vendor/abseil-cpp/absl/strings/internal/str_format/checker.h +100 -0
  699. package/vendor/abseil-cpp/absl/strings/internal/str_format/checker_test.cc +176 -0
  700. package/vendor/abseil-cpp/absl/strings/internal/str_format/constexpr_parser.h +351 -0
  701. package/vendor/abseil-cpp/absl/strings/internal/str_format/convert_test.cc +1257 -0
  702. package/vendor/abseil-cpp/absl/strings/internal/str_format/extension.cc +75 -0
  703. package/vendor/abseil-cpp/absl/strings/internal/str_format/extension.h +450 -0
  704. package/vendor/abseil-cpp/absl/strings/internal/str_format/extension_test.cc +109 -0
  705. package/vendor/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +1457 -0
  706. package/vendor/abseil-cpp/absl/strings/internal/str_format/float_conversion.h +37 -0
  707. package/vendor/abseil-cpp/absl/strings/internal/str_format/output.cc +72 -0
  708. package/vendor/abseil-cpp/absl/strings/internal/str_format/output.h +97 -0
  709. package/vendor/abseil-cpp/absl/strings/internal/str_format/output_test.cc +79 -0
  710. package/vendor/abseil-cpp/absl/strings/internal/str_format/parser.cc +140 -0
  711. package/vendor/abseil-cpp/absl/strings/internal/str_format/parser.h +268 -0
  712. package/vendor/abseil-cpp/absl/strings/internal/str_format/parser_test.cc +438 -0
  713. package/vendor/abseil-cpp/absl/strings/internal/str_join_internal.h +317 -0
  714. package/vendor/abseil-cpp/absl/strings/internal/str_split_internal.h +431 -0
  715. package/vendor/abseil-cpp/absl/strings/internal/string_constant.h +72 -0
  716. package/vendor/abseil-cpp/absl/strings/internal/string_constant_test.cc +60 -0
  717. package/vendor/abseil-cpp/absl/strings/internal/stringify_sink.cc +28 -0
  718. package/vendor/abseil-cpp/absl/strings/internal/stringify_sink.h +57 -0
  719. package/vendor/abseil-cpp/absl/strings/internal/utf8.cc +53 -0
  720. package/vendor/abseil-cpp/absl/strings/internal/utf8.h +50 -0
  721. package/vendor/abseil-cpp/absl/strings/internal/utf8_test.cc +66 -0
  722. package/vendor/abseil-cpp/absl/strings/match.cc +43 -0
  723. package/vendor/abseil-cpp/absl/strings/match.h +100 -0
  724. package/vendor/abseil-cpp/absl/strings/match_test.cc +127 -0
  725. package/vendor/abseil-cpp/absl/strings/numbers.cc +1096 -0
  726. package/vendor/abseil-cpp/absl/strings/numbers.h +303 -0
  727. package/vendor/abseil-cpp/absl/strings/numbers_benchmark.cc +286 -0
  728. package/vendor/abseil-cpp/absl/strings/numbers_test.cc +1722 -0
  729. package/vendor/abseil-cpp/absl/strings/str_cat.cc +249 -0
  730. package/vendor/abseil-cpp/absl/strings/str_cat.h +462 -0
  731. package/vendor/abseil-cpp/absl/strings/str_cat_benchmark.cc +187 -0
  732. package/vendor/abseil-cpp/absl/strings/str_cat_test.cc +665 -0
  733. package/vendor/abseil-cpp/absl/strings/str_format.h +874 -0
  734. package/vendor/abseil-cpp/absl/strings/str_format_test.cc +1212 -0
  735. package/vendor/abseil-cpp/absl/strings/str_join.h +287 -0
  736. package/vendor/abseil-cpp/absl/strings/str_join_benchmark.cc +97 -0
  737. package/vendor/abseil-cpp/absl/strings/str_join_test.cc +608 -0
  738. package/vendor/abseil-cpp/absl/strings/str_replace.cc +82 -0
  739. package/vendor/abseil-cpp/absl/strings/str_replace.h +219 -0
  740. package/vendor/abseil-cpp/absl/strings/str_replace_benchmark.cc +122 -0
  741. package/vendor/abseil-cpp/absl/strings/str_replace_test.cc +341 -0
  742. package/vendor/abseil-cpp/absl/strings/str_split.cc +139 -0
  743. package/vendor/abseil-cpp/absl/strings/str_split.h +547 -0
  744. package/vendor/abseil-cpp/absl/strings/str_split_benchmark.cc +180 -0
  745. package/vendor/abseil-cpp/absl/strings/str_split_test.cc +981 -0
  746. package/vendor/abseil-cpp/absl/strings/string_view.cc +219 -0
  747. package/vendor/abseil-cpp/absl/strings/string_view.h +704 -0
  748. package/vendor/abseil-cpp/absl/strings/string_view_benchmark.cc +381 -0
  749. package/vendor/abseil-cpp/absl/strings/string_view_test.cc +1308 -0
  750. package/vendor/abseil-cpp/absl/strings/strip.h +93 -0
  751. package/vendor/abseil-cpp/absl/strings/strip_test.cc +198 -0
  752. package/vendor/abseil-cpp/absl/strings/substitute.cc +174 -0
  753. package/vendor/abseil-cpp/absl/strings/substitute.h +755 -0
  754. package/vendor/abseil-cpp/absl/strings/substitute_test.cc +285 -0
  755. package/vendor/abseil-cpp/absl/synchronization/BUILD.bazel +333 -0
  756. package/vendor/abseil-cpp/absl/synchronization/CMakeLists.txt +235 -0
  757. package/vendor/abseil-cpp/absl/synchronization/barrier.cc +52 -0
  758. package/vendor/abseil-cpp/absl/synchronization/barrier.h +79 -0
  759. package/vendor/abseil-cpp/absl/synchronization/barrier_test.cc +75 -0
  760. package/vendor/abseil-cpp/absl/synchronization/blocking_counter.cc +67 -0
  761. package/vendor/abseil-cpp/absl/synchronization/blocking_counter.h +101 -0
  762. package/vendor/abseil-cpp/absl/synchronization/blocking_counter_benchmark.cc +83 -0
  763. package/vendor/abseil-cpp/absl/synchronization/blocking_counter_test.cc +80 -0
  764. package/vendor/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +143 -0
  765. package/vendor/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +56 -0
  766. package/vendor/abseil-cpp/absl/synchronization/internal/futex.h +157 -0
  767. package/vendor/abseil-cpp/absl/synchronization/internal/graphcycles.cc +704 -0
  768. package/vendor/abseil-cpp/absl/synchronization/internal/graphcycles.h +141 -0
  769. package/vendor/abseil-cpp/absl/synchronization/internal/graphcycles_benchmark.cc +44 -0
  770. package/vendor/abseil-cpp/absl/synchronization/internal/graphcycles_test.cc +464 -0
  771. package/vendor/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +170 -0
  772. package/vendor/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +102 -0
  773. package/vendor/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +110 -0
  774. package/vendor/abseil-cpp/absl/synchronization/internal/per_thread_sem_test.cc +190 -0
  775. package/vendor/abseil-cpp/absl/synchronization/internal/thread_pool.h +96 -0
  776. package/vendor/abseil-cpp/absl/synchronization/internal/waiter.cc +403 -0
  777. package/vendor/abseil-cpp/absl/synchronization/internal/waiter.h +161 -0
  778. package/vendor/abseil-cpp/absl/synchronization/lifetime_test.cc +181 -0
  779. package/vendor/abseil-cpp/absl/synchronization/mutex.cc +2835 -0
  780. package/vendor/abseil-cpp/absl/synchronization/mutex.h +1129 -0
  781. package/vendor/abseil-cpp/absl/synchronization/mutex_benchmark.cc +310 -0
  782. package/vendor/abseil-cpp/absl/synchronization/mutex_method_pointer_test.cc +138 -0
  783. package/vendor/abseil-cpp/absl/synchronization/mutex_test.cc +1733 -0
  784. package/vendor/abseil-cpp/absl/synchronization/notification.cc +77 -0
  785. package/vendor/abseil-cpp/absl/synchronization/notification.h +123 -0
  786. package/vendor/abseil-cpp/absl/synchronization/notification_test.cc +133 -0
  787. package/vendor/abseil-cpp/absl/time/BUILD.bazel +148 -0
  788. package/vendor/abseil-cpp/absl/time/CMakeLists.txt +140 -0
  789. package/vendor/abseil-cpp/absl/time/civil_time.cc +199 -0
  790. package/vendor/abseil-cpp/absl/time/civil_time.h +563 -0
  791. package/vendor/abseil-cpp/absl/time/civil_time_benchmark.cc +127 -0
  792. package/vendor/abseil-cpp/absl/time/civil_time_test.cc +1243 -0
  793. package/vendor/abseil-cpp/absl/time/clock.cc +591 -0
  794. package/vendor/abseil-cpp/absl/time/clock.h +74 -0
  795. package/vendor/abseil-cpp/absl/time/clock_benchmark.cc +74 -0
  796. package/vendor/abseil-cpp/absl/time/clock_test.cc +122 -0
  797. package/vendor/abseil-cpp/absl/time/duration.cc +955 -0
  798. package/vendor/abseil-cpp/absl/time/duration_benchmark.cc +444 -0
  799. package/vendor/abseil-cpp/absl/time/duration_test.cc +1856 -0
  800. package/vendor/abseil-cpp/absl/time/flag_test.cc +147 -0
  801. package/vendor/abseil-cpp/absl/time/format.cc +161 -0
  802. package/vendor/abseil-cpp/absl/time/format_benchmark.cc +64 -0
  803. package/vendor/abseil-cpp/absl/time/format_test.cc +441 -0
  804. package/vendor/abseil-cpp/absl/time/internal/cctz/BUILD.bazel +159 -0
  805. package/vendor/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time.h +332 -0
  806. package/vendor/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +632 -0
  807. package/vendor/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +459 -0
  808. package/vendor/abseil-cpp/absl/time/internal/cctz/include/cctz/zone_info_source.h +102 -0
  809. package/vendor/abseil-cpp/absl/time/internal/cctz/src/cctz_benchmark.cc +1033 -0
  810. package/vendor/abseil-cpp/absl/time/internal/cctz/src/civil_time_detail.cc +94 -0
  811. package/vendor/abseil-cpp/absl/time/internal/cctz/src/civil_time_test.cc +1066 -0
  812. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +140 -0
  813. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.h +52 -0
  814. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +1029 -0
  815. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_format_test.cc +1688 -0
  816. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +45 -0
  817. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.h +77 -0
  818. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +113 -0
  819. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +93 -0
  820. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +1048 -0
  821. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +137 -0
  822. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +315 -0
  823. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +55 -0
  824. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +237 -0
  825. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup_test.cc +1504 -0
  826. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.cc +159 -0
  827. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.h +132 -0
  828. package/vendor/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +122 -0
  829. package/vendor/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +116 -0
  830. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/README.zoneinfo +38 -0
  831. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/version +1 -0
  832. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Abidjan +0 -0
  833. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Accra +0 -0
  834. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Addis_Ababa +0 -0
  835. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Algiers +0 -0
  836. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Asmara +0 -0
  837. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Asmera +0 -0
  838. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bamako +0 -0
  839. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bangui +0 -0
  840. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Banjul +0 -0
  841. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bissau +0 -0
  842. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Blantyre +0 -0
  843. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Brazzaville +0 -0
  844. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Bujumbura +0 -0
  845. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Cairo +0 -0
  846. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Casablanca +0 -0
  847. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ceuta +0 -0
  848. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Conakry +0 -0
  849. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Dakar +0 -0
  850. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Dar_es_Salaam +0 -0
  851. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Djibouti +0 -0
  852. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Douala +0 -0
  853. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/El_Aaiun +0 -0
  854. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Freetown +0 -0
  855. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Gaborone +0 -0
  856. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Harare +0 -0
  857. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Johannesburg +0 -0
  858. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Juba +0 -0
  859. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kampala +0 -0
  860. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Khartoum +0 -0
  861. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kigali +0 -0
  862. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Kinshasa +0 -0
  863. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lagos +0 -0
  864. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Libreville +0 -0
  865. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lome +0 -0
  866. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Luanda +0 -0
  867. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lubumbashi +0 -0
  868. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Lusaka +0 -0
  869. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Malabo +0 -0
  870. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Maputo +0 -0
  871. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Maseru +0 -0
  872. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Mbabane +0 -0
  873. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Mogadishu +0 -0
  874. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Monrovia +0 -0
  875. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Nairobi +0 -0
  876. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ndjamena +0 -0
  877. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Niamey +0 -0
  878. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Nouakchott +0 -0
  879. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Ouagadougou +0 -0
  880. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Porto-Novo +0 -0
  881. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Sao_Tome +0 -0
  882. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Timbuktu +0 -0
  883. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Tripoli +0 -0
  884. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Tunis +0 -0
  885. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Africa/Windhoek +0 -0
  886. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Adak +0 -0
  887. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Anchorage +0 -0
  888. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Anguilla +0 -0
  889. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Antigua +0 -0
  890. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Araguaina +0 -0
  891. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Buenos_Aires +0 -0
  892. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Catamarca +0 -0
  893. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/ComodRivadavia +0 -0
  894. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Cordoba +0 -0
  895. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Jujuy +0 -0
  896. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/La_Rioja +0 -0
  897. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Mendoza +0 -0
  898. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Rio_Gallegos +0 -0
  899. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Salta +0 -0
  900. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/San_Juan +0 -0
  901. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/San_Luis +0 -0
  902. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Tucuman +0 -0
  903. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Argentina/Ushuaia +0 -0
  904. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Aruba +0 -0
  905. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Asuncion +0 -0
  906. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Atikokan +0 -0
  907. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Atka +0 -0
  908. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bahia +0 -0
  909. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bahia_Banderas +0 -0
  910. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Barbados +0 -0
  911. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Belem +0 -0
  912. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Belize +0 -0
  913. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Blanc-Sablon +0 -0
  914. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Boa_Vista +0 -0
  915. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Bogota +0 -0
  916. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Boise +0 -0
  917. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Buenos_Aires +0 -0
  918. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cambridge_Bay +0 -0
  919. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Campo_Grande +0 -0
  920. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cancun +0 -0
  921. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Caracas +0 -0
  922. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Catamarca +0 -0
  923. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cayenne +0 -0
  924. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cayman +0 -0
  925. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Chicago +0 -0
  926. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Chihuahua +0 -0
  927. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ciudad_Juarez +0 -0
  928. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Coral_Harbour +0 -0
  929. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cordoba +0 -0
  930. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Costa_Rica +0 -0
  931. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Creston +0 -0
  932. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Cuiaba +0 -0
  933. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Curacao +0 -0
  934. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Danmarkshavn +0 -0
  935. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dawson +0 -0
  936. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dawson_Creek +0 -0
  937. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Denver +0 -0
  938. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Detroit +0 -0
  939. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Dominica +0 -0
  940. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Edmonton +0 -0
  941. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Eirunepe +0 -0
  942. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/El_Salvador +0 -0
  943. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ensenada +0 -0
  944. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fort_Nelson +0 -0
  945. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fort_Wayne +0 -0
  946. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Fortaleza +0 -0
  947. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Glace_Bay +0 -0
  948. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Godthab +0 -0
  949. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Goose_Bay +0 -0
  950. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Grand_Turk +0 -0
  951. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Grenada +0 -0
  952. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guadeloupe +0 -0
  953. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guatemala +0 -0
  954. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guayaquil +0 -0
  955. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Guyana +0 -0
  956. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Halifax +0 -0
  957. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Havana +0 -0
  958. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Hermosillo +0 -0
  959. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Indianapolis +0 -0
  960. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Knox +0 -0
  961. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Marengo +0 -0
  962. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Petersburg +0 -0
  963. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Tell_City +0 -0
  964. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Vevay +0 -0
  965. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Vincennes +0 -0
  966. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indiana/Winamac +0 -0
  967. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Indianapolis +0 -0
  968. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Inuvik +0 -0
  969. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Iqaluit +0 -0
  970. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Jamaica +0 -0
  971. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Jujuy +0 -0
  972. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Juneau +0 -0
  973. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kentucky/Louisville +0 -0
  974. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kentucky/Monticello +0 -0
  975. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Knox_IN +0 -0
  976. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Kralendijk +0 -0
  977. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/La_Paz +0 -0
  978. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Lima +0 -0
  979. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Los_Angeles +0 -0
  980. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Louisville +0 -0
  981. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Lower_Princes +0 -0
  982. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Maceio +0 -0
  983. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Managua +0 -0
  984. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Manaus +0 -0
  985. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Marigot +0 -0
  986. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Martinique +0 -0
  987. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Matamoros +0 -0
  988. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mazatlan +0 -0
  989. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mendoza +0 -0
  990. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Menominee +0 -0
  991. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Merida +0 -0
  992. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Metlakatla +0 -0
  993. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Mexico_City +0 -0
  994. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Miquelon +0 -0
  995. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Moncton +0 -0
  996. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Monterrey +0 -0
  997. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montevideo +0 -0
  998. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montreal +0 -0
  999. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Montserrat +0 -0
  1000. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nassau +0 -0
  1001. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/New_York +0 -0
  1002. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nipigon +0 -0
  1003. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nome +0 -0
  1004. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Noronha +0 -0
  1005. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/Beulah +0 -0
  1006. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/Center +0 -0
  1007. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/North_Dakota/New_Salem +0 -0
  1008. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Nuuk +0 -0
  1009. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Ojinaga +0 -0
  1010. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Panama +0 -0
  1011. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Pangnirtung +0 -0
  1012. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Paramaribo +0 -0
  1013. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Phoenix +0 -0
  1014. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Port-au-Prince +0 -0
  1015. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Port_of_Spain +0 -0
  1016. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Porto_Acre +0 -0
  1017. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Porto_Velho +0 -0
  1018. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Puerto_Rico +0 -0
  1019. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Punta_Arenas +0 -0
  1020. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rainy_River +0 -0
  1021. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rankin_Inlet +0 -0
  1022. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Recife +0 -0
  1023. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Regina +0 -0
  1024. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Resolute +0 -0
  1025. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rio_Branco +0 -0
  1026. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Rosario +0 -0
  1027. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santa_Isabel +0 -0
  1028. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santarem +0 -0
  1029. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santiago +0 -0
  1030. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Santo_Domingo +0 -0
  1031. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Sao_Paulo +0 -0
  1032. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Scoresbysund +0 -0
  1033. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Shiprock +0 -0
  1034. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Sitka +0 -0
  1035. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Barthelemy +0 -0
  1036. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Johns +0 -0
  1037. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Kitts +0 -0
  1038. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Lucia +0 -0
  1039. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Thomas +0 -0
  1040. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/St_Vincent +0 -0
  1041. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Swift_Current +0 -0
  1042. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tegucigalpa +0 -0
  1043. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Thule +0 -0
  1044. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Thunder_Bay +0 -0
  1045. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tijuana +0 -0
  1046. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Toronto +0 -0
  1047. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Tortola +0 -0
  1048. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Vancouver +0 -0
  1049. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Virgin +0 -0
  1050. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Whitehorse +0 -0
  1051. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Winnipeg +0 -0
  1052. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Yakutat +0 -0
  1053. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Yellowknife +0 -0
  1054. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Casey +0 -0
  1055. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Davis +0 -0
  1056. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/DumontDUrville +0 -0
  1057. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Macquarie +0 -0
  1058. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Mawson +0 -0
  1059. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/McMurdo +0 -0
  1060. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Palmer +0 -0
  1061. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Rothera +0 -0
  1062. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/South_Pole +0 -0
  1063. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Syowa +0 -0
  1064. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Troll +0 -0
  1065. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Antarctica/Vostok +0 -0
  1066. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Arctic/Longyearbyen +0 -0
  1067. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aden +0 -0
  1068. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Almaty +0 -0
  1069. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Amman +0 -0
  1070. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Anadyr +0 -0
  1071. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aqtau +0 -0
  1072. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Aqtobe +0 -0
  1073. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ashgabat +0 -0
  1074. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ashkhabad +0 -0
  1075. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Atyrau +0 -0
  1076. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Baghdad +0 -0
  1077. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bahrain +0 -0
  1078. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Baku +0 -0
  1079. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bangkok +0 -0
  1080. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Barnaul +0 -0
  1081. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Beirut +0 -0
  1082. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Bishkek +0 -0
  1083. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Brunei +0 -0
  1084. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Calcutta +0 -0
  1085. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chita +0 -0
  1086. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Choibalsan +0 -0
  1087. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chongqing +0 -0
  1088. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Chungking +0 -0
  1089. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Colombo +0 -0
  1090. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dacca +0 -0
  1091. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Damascus +0 -0
  1092. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dhaka +0 -0
  1093. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dili +0 -0
  1094. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dubai +0 -0
  1095. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Dushanbe +0 -0
  1096. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Famagusta +0 -0
  1097. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Gaza +0 -0
  1098. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Harbin +0 -0
  1099. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hebron +0 -0
  1100. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ho_Chi_Minh +0 -0
  1101. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hong_Kong +0 -0
  1102. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Hovd +0 -0
  1103. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Irkutsk +0 -0
  1104. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Istanbul +0 -0
  1105. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jakarta +0 -0
  1106. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jayapura +0 -0
  1107. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Jerusalem +0 -0
  1108. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kabul +0 -0
  1109. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kamchatka +0 -0
  1110. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Karachi +0 -0
  1111. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kashgar +0 -0
  1112. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kathmandu +0 -0
  1113. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Katmandu +0 -0
  1114. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Khandyga +0 -0
  1115. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kolkata +0 -0
  1116. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Krasnoyarsk +0 -0
  1117. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuala_Lumpur +0 -0
  1118. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuching +0 -0
  1119. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Kuwait +0 -0
  1120. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Macao +0 -0
  1121. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Macau +0 -0
  1122. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Magadan +0 -0
  1123. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Makassar +0 -0
  1124. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Manila +0 -0
  1125. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Muscat +0 -0
  1126. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Nicosia +0 -0
  1127. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Novokuznetsk +0 -0
  1128. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Novosibirsk +0 -0
  1129. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Omsk +0 -0
  1130. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Oral +0 -0
  1131. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Phnom_Penh +0 -0
  1132. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Pontianak +0 -0
  1133. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Pyongyang +0 -0
  1134. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qatar +0 -0
  1135. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qostanay +0 -0
  1136. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Qyzylorda +0 -0
  1137. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Rangoon +0 -0
  1138. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Riyadh +0 -0
  1139. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Saigon +0 -0
  1140. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Sakhalin +0 -0
  1141. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Samarkand +0 -0
  1142. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Seoul +0 -0
  1143. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Shanghai +0 -0
  1144. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Singapore +0 -0
  1145. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Srednekolymsk +0 -0
  1146. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Taipei +0 -0
  1147. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tashkent +0 -0
  1148. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tbilisi +0 -0
  1149. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tehran +0 -0
  1150. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tel_Aviv +0 -0
  1151. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Thimbu +0 -0
  1152. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Thimphu +0 -0
  1153. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tokyo +0 -0
  1154. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tomsk +0 -0
  1155. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ujung_Pandang +0 -0
  1156. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ulaanbaatar +0 -0
  1157. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ulan_Bator +0 -0
  1158. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Urumqi +0 -0
  1159. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Ust-Nera +0 -0
  1160. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Vientiane +0 -0
  1161. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Vladivostok +0 -0
  1162. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yakutsk +0 -0
  1163. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yangon +0 -0
  1164. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yekaterinburg +0 -0
  1165. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Yerevan +0 -0
  1166. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Azores +0 -0
  1167. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Bermuda +0 -0
  1168. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Canary +0 -0
  1169. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Cape_Verde +0 -0
  1170. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Faeroe +0 -0
  1171. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Faroe +0 -0
  1172. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Jan_Mayen +0 -0
  1173. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Madeira +0 -0
  1174. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Reykjavik +0 -0
  1175. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/South_Georgia +0 -0
  1176. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/St_Helena +0 -0
  1177. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Atlantic/Stanley +0 -0
  1178. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/ACT +0 -0
  1179. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Adelaide +0 -0
  1180. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Brisbane +0 -0
  1181. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Broken_Hill +0 -0
  1182. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Canberra +0 -0
  1183. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Currie +0 -0
  1184. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Darwin +0 -0
  1185. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Eucla +0 -0
  1186. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Hobart +0 -0
  1187. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/LHI +0 -0
  1188. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Lindeman +0 -0
  1189. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Lord_Howe +0 -0
  1190. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Melbourne +0 -0
  1191. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/NSW +0 -0
  1192. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/North +0 -0
  1193. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Perth +0 -0
  1194. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Queensland +0 -0
  1195. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/South +0 -0
  1196. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Sydney +0 -0
  1197. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Tasmania +0 -0
  1198. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Victoria +0 -0
  1199. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/West +0 -0
  1200. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Australia/Yancowinna +0 -0
  1201. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/Acre +0 -0
  1202. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/DeNoronha +0 -0
  1203. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/East +0 -0
  1204. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Brazil/West +0 -0
  1205. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/CET +0 -0
  1206. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/CST6CDT +0 -0
  1207. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Atlantic +0 -0
  1208. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Central +0 -0
  1209. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Eastern +0 -0
  1210. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Mountain +0 -0
  1211. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Newfoundland +0 -0
  1212. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Pacific +0 -0
  1213. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Saskatchewan +0 -0
  1214. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Canada/Yukon +0 -0
  1215. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Chile/Continental +0 -0
  1216. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Chile/EasterIsland +0 -0
  1217. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Cuba +0 -0
  1218. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EET +0 -0
  1219. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EST +0 -0
  1220. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/EST5EDT +0 -0
  1221. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Egypt +0 -0
  1222. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Eire +0 -0
  1223. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT +0 -0
  1224. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+0 +0 -0
  1225. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+1 +0 -0
  1226. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+10 +0 -0
  1227. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+11 +0 -0
  1228. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+12 +0 -0
  1229. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+2 +0 -0
  1230. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+3 +0 -0
  1231. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+4 +0 -0
  1232. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+5 +0 -0
  1233. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+6 +0 -0
  1234. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+7 +0 -0
  1235. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+8 +0 -0
  1236. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT+9 +0 -0
  1237. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-0 +0 -0
  1238. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-1 +0 -0
  1239. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-10 +0 -0
  1240. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-11 +0 -0
  1241. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-12 +0 -0
  1242. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-13 +0 -0
  1243. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-14 +0 -0
  1244. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-2 +0 -0
  1245. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-3 +0 -0
  1246. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-4 +0 -0
  1247. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-5 +0 -0
  1248. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-6 +0 -0
  1249. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-7 +0 -0
  1250. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-8 +0 -0
  1251. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT-9 +0 -0
  1252. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/GMT0 +0 -0
  1253. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Greenwich +0 -0
  1254. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/UCT +0 -0
  1255. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/UTC +0 -0
  1256. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Universal +0 -0
  1257. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Etc/Zulu +0 -0
  1258. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Amsterdam +0 -0
  1259. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Andorra +0 -0
  1260. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Astrakhan +0 -0
  1261. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Athens +0 -0
  1262. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Belfast +0 -0
  1263. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Belgrade +0 -0
  1264. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Berlin +0 -0
  1265. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Bratislava +0 -0
  1266. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Brussels +0 -0
  1267. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Bucharest +0 -0
  1268. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Budapest +0 -0
  1269. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Busingen +0 -0
  1270. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Chisinau +0 -0
  1271. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Copenhagen +0 -0
  1272. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Dublin +0 -0
  1273. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Gibraltar +0 -0
  1274. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Guernsey +0 -0
  1275. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Helsinki +0 -0
  1276. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Isle_of_Man +0 -0
  1277. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Istanbul +0 -0
  1278. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Jersey +0 -0
  1279. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kaliningrad +0 -0
  1280. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kiev +0 -0
  1281. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kirov +0 -0
  1282. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Kyiv +0 -0
  1283. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Lisbon +0 -0
  1284. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Ljubljana +0 -0
  1285. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/London +0 -0
  1286. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Luxembourg +0 -0
  1287. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Madrid +0 -0
  1288. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Malta +0 -0
  1289. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Mariehamn +0 -0
  1290. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Minsk +0 -0
  1291. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Monaco +0 -0
  1292. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Moscow +0 -0
  1293. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Nicosia +0 -0
  1294. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Oslo +0 -0
  1295. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Paris +0 -0
  1296. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Podgorica +0 -0
  1297. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Prague +0 -0
  1298. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Riga +0 -0
  1299. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Rome +0 -0
  1300. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Samara +0 -0
  1301. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/San_Marino +0 -0
  1302. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Sarajevo +0 -0
  1303. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Saratov +0 -0
  1304. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Simferopol +0 -0
  1305. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Skopje +0 -0
  1306. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Sofia +0 -0
  1307. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Stockholm +0 -0
  1308. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tallinn +0 -0
  1309. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tirane +0 -0
  1310. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Tiraspol +0 -0
  1311. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Ulyanovsk +0 -0
  1312. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Uzhgorod +0 -0
  1313. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vaduz +0 -0
  1314. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vatican +0 -0
  1315. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vienna +0 -0
  1316. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Vilnius +0 -0
  1317. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Volgograd +0 -0
  1318. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Warsaw +0 -0
  1319. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zagreb +0 -0
  1320. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zaporozhye +0 -0
  1321. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Europe/Zurich +0 -0
  1322. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Factory +0 -0
  1323. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GB +0 -0
  1324. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GB-Eire +0 -0
  1325. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT +0 -0
  1326. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT+0 +0 -0
  1327. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT-0 +0 -0
  1328. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/GMT0 +0 -0
  1329. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Greenwich +0 -0
  1330. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/HST +0 -0
  1331. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Hongkong +0 -0
  1332. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Iceland +0 -0
  1333. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Antananarivo +0 -0
  1334. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Chagos +0 -0
  1335. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Christmas +0 -0
  1336. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Cocos +0 -0
  1337. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Comoro +0 -0
  1338. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Kerguelen +0 -0
  1339. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mahe +0 -0
  1340. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Maldives +0 -0
  1341. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mauritius +0 -0
  1342. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Mayotte +0 -0
  1343. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Indian/Reunion +0 -0
  1344. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Iran +0 -0
  1345. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Israel +0 -0
  1346. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Jamaica +0 -0
  1347. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Japan +0 -0
  1348. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Kwajalein +0 -0
  1349. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Libya +0 -0
  1350. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MET +0 -0
  1351. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MST +0 -0
  1352. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/MST7MDT +0 -0
  1353. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/BajaNorte +0 -0
  1354. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/BajaSur +0 -0
  1355. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Mexico/General +0 -0
  1356. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/NZ +0 -0
  1357. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/NZ-CHAT +0 -0
  1358. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Navajo +0 -0
  1359. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/PRC +0 -0
  1360. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/PST8PDT +0 -0
  1361. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Apia +0 -0
  1362. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Auckland +0 -0
  1363. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Bougainville +0 -0
  1364. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Chatham +0 -0
  1365. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Chuuk +0 -0
  1366. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Easter +0 -0
  1367. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Efate +0 -0
  1368. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Enderbury +0 -0
  1369. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Fakaofo +0 -0
  1370. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Fiji +0 -0
  1371. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Funafuti +0 -0
  1372. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Galapagos +0 -0
  1373. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Gambier +0 -0
  1374. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Guadalcanal +0 -0
  1375. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Guam +0 -0
  1376. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Honolulu +0 -0
  1377. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Johnston +0 -0
  1378. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kanton +0 -0
  1379. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kiritimati +0 -0
  1380. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kosrae +0 -0
  1381. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Kwajalein +0 -0
  1382. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Majuro +0 -0
  1383. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Marquesas +0 -0
  1384. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Midway +0 -0
  1385. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Nauru +0 -0
  1386. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Niue +0 -0
  1387. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Norfolk +0 -0
  1388. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Noumea +0 -0
  1389. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pago_Pago +0 -0
  1390. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Palau +0 -0
  1391. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pitcairn +0 -0
  1392. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Pohnpei +0 -0
  1393. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Ponape +0 -0
  1394. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Port_Moresby +0 -0
  1395. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Rarotonga +0 -0
  1396. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Saipan +0 -0
  1397. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Samoa +0 -0
  1398. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tahiti +0 -0
  1399. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tarawa +0 -0
  1400. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Tongatapu +0 -0
  1401. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Truk +0 -0
  1402. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Wake +0 -0
  1403. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Wallis +0 -0
  1404. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Pacific/Yap +0 -0
  1405. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Poland +0 -0
  1406. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Portugal +0 -0
  1407. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/ROC +0 -0
  1408. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/ROK +0 -0
  1409. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Singapore +0 -0
  1410. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Turkey +0 -0
  1411. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/UCT +0 -0
  1412. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Alaska +0 -0
  1413. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Aleutian +0 -0
  1414. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Arizona +0 -0
  1415. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Central +0 -0
  1416. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/East-Indiana +0 -0
  1417. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Eastern +0 -0
  1418. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Hawaii +0 -0
  1419. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Indiana-Starke +0 -0
  1420. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Michigan +0 -0
  1421. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Mountain +0 -0
  1422. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Pacific +0 -0
  1423. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/US/Samoa +0 -0
  1424. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/UTC +0 -0
  1425. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Universal +0 -0
  1426. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/W-SU +0 -0
  1427. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/WET +0 -0
  1428. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Zulu +0 -0
  1429. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/iso3166.tab +274 -0
  1430. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/zone1970.tab +372 -0
  1431. package/vendor/abseil-cpp/absl/time/internal/get_current_time_chrono.inc +31 -0
  1432. package/vendor/abseil-cpp/absl/time/internal/get_current_time_posix.inc +24 -0
  1433. package/vendor/abseil-cpp/absl/time/internal/test_util.cc +32 -0
  1434. package/vendor/abseil-cpp/absl/time/internal/test_util.h +33 -0
  1435. package/vendor/abseil-cpp/absl/time/time.cc +500 -0
  1436. package/vendor/abseil-cpp/absl/time/time.h +1715 -0
  1437. package/vendor/abseil-cpp/absl/time/time_benchmark.cc +321 -0
  1438. package/vendor/abseil-cpp/absl/time/time_test.cc +1290 -0
  1439. package/vendor/abseil-cpp/absl/time/time_zone_test.cc +97 -0
  1440. package/vendor/abseil-cpp/absl/types/BUILD.bazel +336 -0
  1441. package/vendor/abseil-cpp/absl/types/CMakeLists.txt +371 -0
  1442. package/vendor/abseil-cpp/absl/types/any.h +517 -0
  1443. package/vendor/abseil-cpp/absl/types/any_exception_safety_test.cc +173 -0
  1444. package/vendor/abseil-cpp/absl/types/any_test.cc +778 -0
  1445. package/vendor/abseil-cpp/absl/types/bad_any_cast.cc +46 -0
  1446. package/vendor/abseil-cpp/absl/types/bad_any_cast.h +75 -0
  1447. package/vendor/abseil-cpp/absl/types/bad_optional_access.cc +48 -0
  1448. package/vendor/abseil-cpp/absl/types/bad_optional_access.h +78 -0
  1449. package/vendor/abseil-cpp/absl/types/bad_variant_access.cc +64 -0
  1450. package/vendor/abseil-cpp/absl/types/bad_variant_access.h +82 -0
  1451. package/vendor/abseil-cpp/absl/types/compare.h +599 -0
  1452. package/vendor/abseil-cpp/absl/types/compare_test.cc +389 -0
  1453. package/vendor/abseil-cpp/absl/types/internal/conformance_aliases.h +447 -0
  1454. package/vendor/abseil-cpp/absl/types/internal/conformance_archetype.h +978 -0
  1455. package/vendor/abseil-cpp/absl/types/internal/conformance_profile.h +933 -0
  1456. package/vendor/abseil-cpp/absl/types/internal/conformance_testing.h +1386 -0
  1457. package/vendor/abseil-cpp/absl/types/internal/conformance_testing_helpers.h +391 -0
  1458. package/vendor/abseil-cpp/absl/types/internal/conformance_testing_test.cc +1556 -0
  1459. package/vendor/abseil-cpp/absl/types/internal/optional.h +404 -0
  1460. package/vendor/abseil-cpp/absl/types/internal/parentheses.h +34 -0
  1461. package/vendor/abseil-cpp/absl/types/internal/span.h +139 -0
  1462. package/vendor/abseil-cpp/absl/types/internal/transform_args.h +246 -0
  1463. package/vendor/abseil-cpp/absl/types/internal/variant.h +1634 -0
  1464. package/vendor/abseil-cpp/absl/types/optional.h +779 -0
  1465. package/vendor/abseil-cpp/absl/types/optional_exception_safety_test.cc +292 -0
  1466. package/vendor/abseil-cpp/absl/types/optional_test.cc +1675 -0
  1467. package/vendor/abseil-cpp/absl/types/span.h +749 -0
  1468. package/vendor/abseil-cpp/absl/types/span_test.cc +848 -0
  1469. package/vendor/abseil-cpp/absl/types/variant.h +866 -0
  1470. package/vendor/abseil-cpp/absl/types/variant_benchmark.cc +222 -0
  1471. package/vendor/abseil-cpp/absl/types/variant_exception_safety_test.cc +532 -0
  1472. package/vendor/abseil-cpp/absl/types/variant_test.cc +2718 -0
  1473. package/vendor/abseil-cpp/absl/utility/BUILD.bazel +54 -0
  1474. package/vendor/abseil-cpp/absl/utility/CMakeLists.txt +44 -0
  1475. package/vendor/abseil-cpp/absl/utility/utility.h +350 -0
  1476. package/vendor/abseil-cpp/absl/utility/utility_test.cc +376 -0
  1477. package/vendor/abseil-cpp/ci/absl_alternate_options.h +29 -0
  1478. package/vendor/abseil-cpp/ci/cmake_common.sh +25 -0
  1479. package/vendor/abseil-cpp/ci/cmake_install_test.sh +58 -0
  1480. package/vendor/abseil-cpp/ci/linux_clang-latest_libcxx_asan_bazel.sh +102 -0
  1481. package/vendor/abseil-cpp/ci/linux_clang-latest_libcxx_bazel.sh +100 -0
  1482. package/vendor/abseil-cpp/ci/linux_clang-latest_libcxx_tsan_bazel.sh +97 -0
  1483. package/vendor/abseil-cpp/ci/linux_clang-latest_libstdcxx_bazel.sh +95 -0
  1484. package/vendor/abseil-cpp/ci/linux_docker_containers.sh +21 -0
  1485. package/vendor/abseil-cpp/ci/linux_gcc-floor_libstdcxx_bazel.sh +92 -0
  1486. package/vendor/abseil-cpp/ci/linux_gcc-latest_libstdcxx_bazel.sh +98 -0
  1487. package/vendor/abseil-cpp/ci/linux_gcc-latest_libstdcxx_cmake.sh +66 -0
  1488. package/vendor/abseil-cpp/ci/linux_gcc_alpine_cmake.sh +65 -0
  1489. package/vendor/abseil-cpp/ci/macos_xcode_bazel.sh +65 -0
  1490. package/vendor/abseil-cpp/ci/macos_xcode_cmake.sh +57 -0
  1491. package/vendor/abseil-cpp/conanfile.py +51 -0
  1492. package/vendor/abseil-cpp/create_lts.py +133 -0
@@ -0,0 +1,2060 @@
1
+ // Copyright 2019 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
+ #include "absl/container/inlined_vector.h"
16
+
17
+ #include <algorithm>
18
+ #include <forward_list>
19
+ #include <iterator>
20
+ #include <list>
21
+ #include <memory>
22
+ #include <scoped_allocator>
23
+ #include <sstream>
24
+ #include <stdexcept>
25
+ #include <string>
26
+ #include <utility>
27
+ #include <vector>
28
+
29
+ #include "gmock/gmock.h"
30
+ #include "gtest/gtest.h"
31
+ #include "absl/base/attributes.h"
32
+ #include "absl/base/internal/exception_testing.h"
33
+ #include "absl/base/internal/raw_logging.h"
34
+ #include "absl/base/macros.h"
35
+ #include "absl/base/options.h"
36
+ #include "absl/container/internal/counting_allocator.h"
37
+ #include "absl/container/internal/test_instance_tracker.h"
38
+ #include "absl/hash/hash_testing.h"
39
+ #include "absl/memory/memory.h"
40
+ #include "absl/strings/str_cat.h"
41
+
42
+ namespace {
43
+
44
+ using absl::container_internal::CountingAllocator;
45
+ using absl::test_internal::CopyableMovableInstance;
46
+ using absl::test_internal::CopyableOnlyInstance;
47
+ using absl::test_internal::InstanceTracker;
48
+ using testing::AllOf;
49
+ using testing::Each;
50
+ using testing::ElementsAre;
51
+ using testing::ElementsAreArray;
52
+ using testing::Eq;
53
+ using testing::Gt;
54
+ using testing::Pointwise;
55
+ using testing::PrintToString;
56
+
57
+ using IntVec = absl::InlinedVector<int, 8>;
58
+
59
+ MATCHER_P(SizeIs, n, "") {
60
+ return testing::ExplainMatchResult(n, arg.size(), result_listener);
61
+ }
62
+
63
+ MATCHER_P(CapacityIs, n, "") {
64
+ return testing::ExplainMatchResult(n, arg.capacity(), result_listener);
65
+ }
66
+
67
+ MATCHER_P(ValueIs, e, "") {
68
+ return testing::ExplainMatchResult(e, arg.value(), result_listener);
69
+ }
70
+
71
+ // TODO(bsamwel): Add support for movable-only types.
72
+
73
+ // Test fixture for typed tests on BaseCountedInstance derived classes, see
74
+ // test_instance_tracker.h.
75
+ template <typename T>
76
+ class InstanceTest : public ::testing::Test {};
77
+ TYPED_TEST_SUITE_P(InstanceTest);
78
+
79
+ // A simple reference counted class to make sure that the proper elements are
80
+ // destroyed in the erase(begin, end) test.
81
+ class RefCounted {
82
+ public:
83
+ RefCounted(int value, int* count) : value_(value), count_(count) { Ref(); }
84
+
85
+ RefCounted(const RefCounted& v) : value_(v.value_), count_(v.count_) {
86
+ Ref();
87
+ }
88
+
89
+ ~RefCounted() {
90
+ Unref();
91
+ count_ = nullptr;
92
+ }
93
+
94
+ friend void swap(RefCounted& a, RefCounted& b) {
95
+ using std::swap;
96
+ swap(a.value_, b.value_);
97
+ swap(a.count_, b.count_);
98
+ }
99
+
100
+ RefCounted& operator=(RefCounted v) {
101
+ using std::swap;
102
+ swap(*this, v);
103
+ return *this;
104
+ }
105
+
106
+ void Ref() const {
107
+ ABSL_RAW_CHECK(count_ != nullptr, "");
108
+ ++(*count_);
109
+ }
110
+
111
+ void Unref() const {
112
+ --(*count_);
113
+ ABSL_RAW_CHECK(*count_ >= 0, "");
114
+ }
115
+
116
+ int value_;
117
+ int* count_;
118
+ };
119
+
120
+ using RefCountedVec = absl::InlinedVector<RefCounted, 8>;
121
+
122
+ // A class with a vtable pointer
123
+ class Dynamic {
124
+ public:
125
+ virtual ~Dynamic() {}
126
+ };
127
+
128
+ using DynamicVec = absl::InlinedVector<Dynamic, 8>;
129
+
130
+ // Append 0..len-1 to *v
131
+ template <typename Container>
132
+ static void Fill(Container* v, size_t len, int offset = 0) {
133
+ for (size_t i = 0; i < len; i++) {
134
+ v->push_back(static_cast<int>(i) + offset);
135
+ }
136
+ }
137
+
138
+ static IntVec Fill(size_t len, int offset = 0) {
139
+ IntVec v;
140
+ Fill(&v, len, offset);
141
+ return v;
142
+ }
143
+
144
+ TEST(IntVec, SimpleOps) {
145
+ for (size_t len = 0; len < 20; len++) {
146
+ IntVec v;
147
+ const IntVec& cv = v; // const alias
148
+
149
+ Fill(&v, len);
150
+ EXPECT_EQ(len, v.size());
151
+ EXPECT_LE(len, v.capacity());
152
+
153
+ for (size_t i = 0; i < len; i++) {
154
+ EXPECT_EQ(static_cast<int>(i), v[i]);
155
+ EXPECT_EQ(static_cast<int>(i), v.at(i));
156
+ }
157
+ EXPECT_EQ(v.begin(), v.data());
158
+ EXPECT_EQ(cv.begin(), cv.data());
159
+
160
+ size_t counter = 0;
161
+ for (IntVec::iterator iter = v.begin(); iter != v.end(); ++iter) {
162
+ EXPECT_EQ(static_cast<int>(counter), *iter);
163
+ counter++;
164
+ }
165
+ EXPECT_EQ(counter, len);
166
+
167
+ counter = 0;
168
+ for (IntVec::const_iterator iter = v.begin(); iter != v.end(); ++iter) {
169
+ EXPECT_EQ(static_cast<int>(counter), *iter);
170
+ counter++;
171
+ }
172
+ EXPECT_EQ(counter, len);
173
+
174
+ counter = 0;
175
+ for (IntVec::const_iterator iter = v.cbegin(); iter != v.cend(); ++iter) {
176
+ EXPECT_EQ(static_cast<int>(counter), *iter);
177
+ counter++;
178
+ }
179
+ EXPECT_EQ(counter, len);
180
+
181
+ if (len > 0) {
182
+ EXPECT_EQ(0, v.front());
183
+ EXPECT_EQ(static_cast<int>(len - 1), v.back());
184
+ v.pop_back();
185
+ EXPECT_EQ(len - 1, v.size());
186
+ for (size_t i = 0; i < v.size(); ++i) {
187
+ EXPECT_EQ(static_cast<int>(i), v[i]);
188
+ EXPECT_EQ(static_cast<int>(i), v.at(i));
189
+ }
190
+ }
191
+ }
192
+ }
193
+
194
+ TEST(IntVec, PopBackNoOverflow) {
195
+ IntVec v = {1};
196
+ v.pop_back();
197
+ EXPECT_EQ(v.size(), 0u);
198
+ }
199
+
200
+ TEST(IntVec, AtThrows) {
201
+ IntVec v = {1, 2, 3};
202
+ EXPECT_EQ(v.at(2), 3);
203
+ ABSL_BASE_INTERNAL_EXPECT_FAIL(v.at(3), std::out_of_range,
204
+ "failed bounds check");
205
+ }
206
+
207
+ TEST(IntVec, ReverseIterator) {
208
+ for (size_t len = 0; len < 20; len++) {
209
+ IntVec v;
210
+ Fill(&v, len);
211
+
212
+ size_t counter = len;
213
+ for (IntVec::reverse_iterator iter = v.rbegin(); iter != v.rend(); ++iter) {
214
+ counter--;
215
+ EXPECT_EQ(static_cast<int>(counter), *iter);
216
+ }
217
+ EXPECT_EQ(counter, 0u);
218
+
219
+ counter = len;
220
+ for (IntVec::const_reverse_iterator iter = v.rbegin(); iter != v.rend();
221
+ ++iter) {
222
+ counter--;
223
+ EXPECT_EQ(static_cast<int>(counter), *iter);
224
+ }
225
+ EXPECT_EQ(counter, 0u);
226
+
227
+ counter = len;
228
+ for (IntVec::const_reverse_iterator iter = v.crbegin(); iter != v.crend();
229
+ ++iter) {
230
+ counter--;
231
+ EXPECT_EQ(static_cast<int>(counter), *iter);
232
+ }
233
+ EXPECT_EQ(counter, 0u);
234
+ }
235
+ }
236
+
237
+ TEST(IntVec, Erase) {
238
+ for (size_t len = 1; len < 20; len++) {
239
+ for (size_t i = 0; i < len; ++i) {
240
+ IntVec v;
241
+ Fill(&v, len);
242
+ v.erase(v.begin() + i);
243
+ EXPECT_EQ(len - 1, v.size());
244
+ for (size_t j = 0; j < i; ++j) {
245
+ EXPECT_EQ(static_cast<int>(j), v[j]);
246
+ }
247
+ for (size_t j = i; j < len - 1; ++j) {
248
+ EXPECT_EQ(static_cast<int>(j + 1), v[j]);
249
+ }
250
+ }
251
+ }
252
+ }
253
+
254
+ TEST(IntVec, Hardened) {
255
+ IntVec v;
256
+ Fill(&v, 10);
257
+ EXPECT_EQ(v[9], 9);
258
+ #if !defined(NDEBUG) || ABSL_OPTION_HARDENED
259
+ EXPECT_DEATH_IF_SUPPORTED(v[10], "");
260
+ EXPECT_DEATH_IF_SUPPORTED(v[static_cast<size_t>(-1)], "");
261
+ EXPECT_DEATH_IF_SUPPORTED(v.resize(v.max_size() + 1), "");
262
+ #endif
263
+ }
264
+
265
+ // At the end of this test loop, the elements between [erase_begin, erase_end)
266
+ // should have reference counts == 0, and all others elements should have
267
+ // reference counts == 1.
268
+ TEST(RefCountedVec, EraseBeginEnd) {
269
+ for (size_t len = 1; len < 20; ++len) {
270
+ for (size_t erase_begin = 0; erase_begin < len; ++erase_begin) {
271
+ for (size_t erase_end = erase_begin; erase_end <= len; ++erase_end) {
272
+ std::vector<int> counts(len, 0);
273
+ RefCountedVec v;
274
+ for (size_t i = 0; i < len; ++i) {
275
+ v.push_back(RefCounted(static_cast<int>(i), &counts[i]));
276
+ }
277
+
278
+ size_t erase_len = erase_end - erase_begin;
279
+
280
+ v.erase(v.begin() + erase_begin, v.begin() + erase_end);
281
+
282
+ EXPECT_EQ(len - erase_len, v.size());
283
+
284
+ // Check the elements before the first element erased.
285
+ for (size_t i = 0; i < erase_begin; ++i) {
286
+ EXPECT_EQ(static_cast<int>(i), v[i].value_);
287
+ }
288
+
289
+ // Check the elements after the first element erased.
290
+ for (size_t i = erase_begin; i < v.size(); ++i) {
291
+ EXPECT_EQ(static_cast<int>(i + erase_len), v[i].value_);
292
+ }
293
+
294
+ // Check that the elements at the beginning are preserved.
295
+ for (size_t i = 0; i < erase_begin; ++i) {
296
+ EXPECT_EQ(1, counts[i]);
297
+ }
298
+
299
+ // Check that the erased elements are destroyed
300
+ for (size_t i = erase_begin; i < erase_end; ++i) {
301
+ EXPECT_EQ(0, counts[i]);
302
+ }
303
+
304
+ // Check that the elements at the end are preserved.
305
+ for (size_t i = erase_end; i < len; ++i) {
306
+ EXPECT_EQ(1, counts[i]);
307
+ }
308
+ }
309
+ }
310
+ }
311
+ }
312
+
313
+ struct NoDefaultCtor {
314
+ explicit NoDefaultCtor(int) {}
315
+ };
316
+ struct NoCopy {
317
+ NoCopy() {}
318
+ NoCopy(const NoCopy&) = delete;
319
+ };
320
+ struct NoAssign {
321
+ NoAssign() {}
322
+ NoAssign& operator=(const NoAssign&) = delete;
323
+ };
324
+ struct MoveOnly {
325
+ MoveOnly() {}
326
+ MoveOnly(MoveOnly&&) = default;
327
+ MoveOnly& operator=(MoveOnly&&) = default;
328
+ };
329
+ TEST(InlinedVectorTest, NoDefaultCtor) {
330
+ absl::InlinedVector<NoDefaultCtor, 1> v(10, NoDefaultCtor(2));
331
+ (void)v;
332
+ }
333
+ TEST(InlinedVectorTest, NoCopy) {
334
+ absl::InlinedVector<NoCopy, 1> v(10);
335
+ (void)v;
336
+ }
337
+ TEST(InlinedVectorTest, NoAssign) {
338
+ absl::InlinedVector<NoAssign, 1> v(10);
339
+ (void)v;
340
+ }
341
+ TEST(InlinedVectorTest, MoveOnly) {
342
+ absl::InlinedVector<MoveOnly, 2> v;
343
+ v.push_back(MoveOnly{});
344
+ v.push_back(MoveOnly{});
345
+ v.push_back(MoveOnly{});
346
+ v.erase(v.begin());
347
+ v.push_back(MoveOnly{});
348
+ v.erase(v.begin(), v.begin() + 1);
349
+ v.insert(v.begin(), MoveOnly{});
350
+ v.emplace(v.begin());
351
+ v.emplace(v.begin(), MoveOnly{});
352
+ }
353
+ TEST(InlinedVectorTest, Noexcept) {
354
+ EXPECT_TRUE(std::is_nothrow_move_constructible<IntVec>::value);
355
+ EXPECT_TRUE((std::is_nothrow_move_constructible<
356
+ absl::InlinedVector<MoveOnly, 2>>::value));
357
+
358
+ struct MoveCanThrow {
359
+ MoveCanThrow(MoveCanThrow&&) {}
360
+ };
361
+ EXPECT_EQ(absl::default_allocator_is_nothrow::value,
362
+ (std::is_nothrow_move_constructible<
363
+ absl::InlinedVector<MoveCanThrow, 2>>::value));
364
+ }
365
+
366
+ TEST(InlinedVectorTest, EmplaceBack) {
367
+ absl::InlinedVector<std::pair<std::string, int>, 1> v;
368
+
369
+ auto& inlined_element = v.emplace_back("answer", 42);
370
+ EXPECT_EQ(&inlined_element, &v[0]);
371
+ EXPECT_EQ(inlined_element.first, "answer");
372
+ EXPECT_EQ(inlined_element.second, 42);
373
+
374
+ auto& allocated_element = v.emplace_back("taxicab", 1729);
375
+ EXPECT_EQ(&allocated_element, &v[1]);
376
+ EXPECT_EQ(allocated_element.first, "taxicab");
377
+ EXPECT_EQ(allocated_element.second, 1729);
378
+ }
379
+
380
+ TEST(InlinedVectorTest, ShrinkToFitGrowingVector) {
381
+ absl::InlinedVector<std::pair<std::string, int>, 1> v;
382
+
383
+ v.shrink_to_fit();
384
+ EXPECT_EQ(v.capacity(), 1u);
385
+
386
+ v.emplace_back("answer", 42);
387
+ v.shrink_to_fit();
388
+ EXPECT_EQ(v.capacity(), 1u);
389
+
390
+ v.emplace_back("taxicab", 1729);
391
+ EXPECT_GE(v.capacity(), 2u);
392
+ v.shrink_to_fit();
393
+ EXPECT_EQ(v.capacity(), 2u);
394
+
395
+ v.reserve(100);
396
+ EXPECT_GE(v.capacity(), 100u);
397
+ v.shrink_to_fit();
398
+ EXPECT_EQ(v.capacity(), 2u);
399
+ }
400
+
401
+ TEST(InlinedVectorTest, ShrinkToFitEdgeCases) {
402
+ {
403
+ absl::InlinedVector<std::pair<std::string, int>, 1> v;
404
+ v.emplace_back("answer", 42);
405
+ v.emplace_back("taxicab", 1729);
406
+ EXPECT_GE(v.capacity(), 2u);
407
+ v.pop_back();
408
+ v.shrink_to_fit();
409
+ EXPECT_EQ(v.capacity(), 1u);
410
+ EXPECT_EQ(v[0].first, "answer");
411
+ EXPECT_EQ(v[0].second, 42);
412
+ }
413
+
414
+ {
415
+ absl::InlinedVector<std::string, 2> v(100);
416
+ v.resize(0);
417
+ v.shrink_to_fit();
418
+ EXPECT_EQ(v.capacity(), 2u); // inlined capacity
419
+ }
420
+
421
+ {
422
+ absl::InlinedVector<std::string, 2> v(100);
423
+ v.resize(1);
424
+ v.shrink_to_fit();
425
+ EXPECT_EQ(v.capacity(), 2u); // inlined capacity
426
+ }
427
+
428
+ {
429
+ absl::InlinedVector<std::string, 2> v(100);
430
+ v.resize(2);
431
+ v.shrink_to_fit();
432
+ EXPECT_EQ(v.capacity(), 2u);
433
+ }
434
+
435
+ {
436
+ absl::InlinedVector<std::string, 2> v(100);
437
+ v.resize(3);
438
+ v.shrink_to_fit();
439
+ EXPECT_EQ(v.capacity(), 3u);
440
+ }
441
+ }
442
+
443
+ TEST(IntVec, Insert) {
444
+ for (size_t len = 0; len < 20; len++) {
445
+ for (ptrdiff_t pos = 0; pos <= static_cast<ptrdiff_t>(len); pos++) {
446
+ {
447
+ // Single element
448
+ std::vector<int> std_v;
449
+ Fill(&std_v, len);
450
+ IntVec v;
451
+ Fill(&v, len);
452
+
453
+ std_v.insert(std_v.begin() + pos, 9999);
454
+ IntVec::iterator it = v.insert(v.cbegin() + pos, 9999);
455
+ EXPECT_THAT(v, ElementsAreArray(std_v));
456
+ EXPECT_EQ(it, v.cbegin() + pos);
457
+ }
458
+ {
459
+ // n elements
460
+ std::vector<int> std_v;
461
+ Fill(&std_v, len);
462
+ IntVec v;
463
+ Fill(&v, len);
464
+
465
+ IntVec::size_type n = 5;
466
+ std_v.insert(std_v.begin() + pos, n, 9999);
467
+ IntVec::iterator it = v.insert(v.cbegin() + pos, n, 9999);
468
+ EXPECT_THAT(v, ElementsAreArray(std_v));
469
+ EXPECT_EQ(it, v.cbegin() + pos);
470
+ }
471
+ {
472
+ // Iterator range (random access iterator)
473
+ std::vector<int> std_v;
474
+ Fill(&std_v, len);
475
+ IntVec v;
476
+ Fill(&v, len);
477
+
478
+ const std::vector<int> input = {9999, 8888, 7777};
479
+ std_v.insert(std_v.begin() + pos, input.cbegin(), input.cend());
480
+ IntVec::iterator it =
481
+ v.insert(v.cbegin() + pos, input.cbegin(), input.cend());
482
+ EXPECT_THAT(v, ElementsAreArray(std_v));
483
+ EXPECT_EQ(it, v.cbegin() + pos);
484
+ }
485
+ {
486
+ // Iterator range (forward iterator)
487
+ std::vector<int> std_v;
488
+ Fill(&std_v, len);
489
+ IntVec v;
490
+ Fill(&v, len);
491
+
492
+ const std::forward_list<int> input = {9999, 8888, 7777};
493
+ std_v.insert(std_v.begin() + pos, input.cbegin(), input.cend());
494
+ IntVec::iterator it =
495
+ v.insert(v.cbegin() + pos, input.cbegin(), input.cend());
496
+ EXPECT_THAT(v, ElementsAreArray(std_v));
497
+ EXPECT_EQ(it, v.cbegin() + pos);
498
+ }
499
+ {
500
+ // Iterator range (input iterator)
501
+ std::vector<int> std_v;
502
+ Fill(&std_v, len);
503
+ IntVec v;
504
+ Fill(&v, len);
505
+
506
+ std_v.insert(std_v.begin() + pos, {9999, 8888, 7777});
507
+ std::istringstream input("9999 8888 7777");
508
+ IntVec::iterator it =
509
+ v.insert(v.cbegin() + pos, std::istream_iterator<int>(input),
510
+ std::istream_iterator<int>());
511
+ EXPECT_THAT(v, ElementsAreArray(std_v));
512
+ EXPECT_EQ(it, v.cbegin() + pos);
513
+ }
514
+ {
515
+ // Initializer list
516
+ std::vector<int> std_v;
517
+ Fill(&std_v, len);
518
+ IntVec v;
519
+ Fill(&v, len);
520
+
521
+ std_v.insert(std_v.begin() + pos, {9999, 8888});
522
+ IntVec::iterator it = v.insert(v.cbegin() + pos, {9999, 8888});
523
+ EXPECT_THAT(v, ElementsAreArray(std_v));
524
+ EXPECT_EQ(it, v.cbegin() + pos);
525
+ }
526
+ }
527
+ }
528
+ }
529
+
530
+ TEST(RefCountedVec, InsertConstructorDestructor) {
531
+ // Make sure the proper construction/destruction happen during insert
532
+ // operations.
533
+ for (size_t len = 0; len < 20; len++) {
534
+ SCOPED_TRACE(len);
535
+ for (size_t pos = 0; pos <= len; pos++) {
536
+ SCOPED_TRACE(pos);
537
+ std::vector<int> counts(len, 0);
538
+ int inserted_count = 0;
539
+ RefCountedVec v;
540
+ for (size_t i = 0; i < len; ++i) {
541
+ SCOPED_TRACE(i);
542
+ v.push_back(RefCounted(static_cast<int>(i), &counts[i]));
543
+ }
544
+
545
+ EXPECT_THAT(counts, Each(Eq(1)));
546
+
547
+ RefCounted insert_element(9999, &inserted_count);
548
+ EXPECT_EQ(1, inserted_count);
549
+ v.insert(v.begin() + pos, insert_element);
550
+ EXPECT_EQ(2, inserted_count);
551
+ // Check that the elements at the end are preserved.
552
+ EXPECT_THAT(counts, Each(Eq(1)));
553
+ EXPECT_EQ(2, inserted_count);
554
+ }
555
+ }
556
+ }
557
+
558
+ TEST(IntVec, Resize) {
559
+ for (size_t len = 0; len < 20; len++) {
560
+ IntVec v;
561
+ Fill(&v, len);
562
+
563
+ // Try resizing up and down by k elements
564
+ static const int kResizeElem = 1000000;
565
+ for (size_t k = 0; k < 10; k++) {
566
+ // Enlarging resize
567
+ v.resize(len + k, kResizeElem);
568
+ EXPECT_EQ(len + k, v.size());
569
+ EXPECT_LE(len + k, v.capacity());
570
+ for (size_t i = 0; i < len + k; i++) {
571
+ if (i < len) {
572
+ EXPECT_EQ(static_cast<int>(i), v[i]);
573
+ } else {
574
+ EXPECT_EQ(kResizeElem, v[i]);
575
+ }
576
+ }
577
+
578
+ // Shrinking resize
579
+ v.resize(len, kResizeElem);
580
+ EXPECT_EQ(len, v.size());
581
+ EXPECT_LE(len, v.capacity());
582
+ for (size_t i = 0; i < len; i++) {
583
+ EXPECT_EQ(static_cast<int>(i), v[i]);
584
+ }
585
+ }
586
+ }
587
+ }
588
+
589
+ TEST(IntVec, InitWithLength) {
590
+ for (size_t len = 0; len < 20; len++) {
591
+ IntVec v(len, 7);
592
+ EXPECT_EQ(len, v.size());
593
+ EXPECT_LE(len, v.capacity());
594
+ for (size_t i = 0; i < len; i++) {
595
+ EXPECT_EQ(7, v[i]);
596
+ }
597
+ }
598
+ }
599
+
600
+ TEST(IntVec, CopyConstructorAndAssignment) {
601
+ for (size_t len = 0; len < 20; len++) {
602
+ IntVec v;
603
+ Fill(&v, len);
604
+ EXPECT_EQ(len, v.size());
605
+ EXPECT_LE(len, v.capacity());
606
+
607
+ IntVec v2(v);
608
+ EXPECT_TRUE(v == v2) << PrintToString(v) << PrintToString(v2);
609
+
610
+ for (size_t start_len = 0; start_len < 20; start_len++) {
611
+ IntVec v3;
612
+ Fill(&v3, start_len, 99); // Add dummy elements that should go away
613
+ v3 = v;
614
+ EXPECT_TRUE(v == v3) << PrintToString(v) << PrintToString(v3);
615
+ }
616
+ }
617
+ }
618
+
619
+ TEST(IntVec, AliasingCopyAssignment) {
620
+ for (size_t len = 0; len < 20; ++len) {
621
+ IntVec original;
622
+ Fill(&original, len);
623
+ IntVec dup = original;
624
+ dup = *&dup;
625
+ EXPECT_EQ(dup, original);
626
+ }
627
+ }
628
+
629
+ TEST(IntVec, MoveConstructorAndAssignment) {
630
+ for (size_t len = 0; len < 20; len++) {
631
+ IntVec v_in;
632
+ const size_t inlined_capacity = v_in.capacity();
633
+ Fill(&v_in, len);
634
+ EXPECT_EQ(len, v_in.size());
635
+ EXPECT_LE(len, v_in.capacity());
636
+
637
+ {
638
+ IntVec v_temp(v_in);
639
+ auto* old_data = v_temp.data();
640
+ IntVec v_out(std::move(v_temp));
641
+ EXPECT_TRUE(v_in == v_out) << PrintToString(v_in) << PrintToString(v_out);
642
+ if (v_in.size() > inlined_capacity) {
643
+ // Allocation is moved as a whole, data stays in place.
644
+ EXPECT_TRUE(v_out.data() == old_data);
645
+ } else {
646
+ EXPECT_FALSE(v_out.data() == old_data);
647
+ }
648
+ }
649
+ for (size_t start_len = 0; start_len < 20; start_len++) {
650
+ IntVec v_out;
651
+ Fill(&v_out, start_len, 99); // Add dummy elements that should go away
652
+ IntVec v_temp(v_in);
653
+ auto* old_data = v_temp.data();
654
+ v_out = std::move(v_temp);
655
+ EXPECT_TRUE(v_in == v_out) << PrintToString(v_in) << PrintToString(v_out);
656
+ if (v_in.size() > inlined_capacity) {
657
+ // Allocation is moved as a whole, data stays in place.
658
+ EXPECT_TRUE(v_out.data() == old_data);
659
+ } else {
660
+ EXPECT_FALSE(v_out.data() == old_data);
661
+ }
662
+ }
663
+ }
664
+ }
665
+
666
+ class NotTriviallyDestructible {
667
+ public:
668
+ NotTriviallyDestructible() : p_(new int(1)) {}
669
+ explicit NotTriviallyDestructible(int i) : p_(new int(i)) {}
670
+
671
+ NotTriviallyDestructible(const NotTriviallyDestructible& other)
672
+ : p_(new int(*other.p_)) {}
673
+
674
+ NotTriviallyDestructible& operator=(const NotTriviallyDestructible& other) {
675
+ p_ = absl::make_unique<int>(*other.p_);
676
+ return *this;
677
+ }
678
+
679
+ bool operator==(const NotTriviallyDestructible& other) const {
680
+ return *p_ == *other.p_;
681
+ }
682
+
683
+ private:
684
+ std::unique_ptr<int> p_;
685
+ };
686
+
687
+ TEST(AliasingTest, Emplace) {
688
+ for (size_t i = 2; i < 20; ++i) {
689
+ absl::InlinedVector<NotTriviallyDestructible, 10> vec;
690
+ for (size_t j = 0; j < i; ++j) {
691
+ vec.push_back(NotTriviallyDestructible(static_cast<int>(j)));
692
+ }
693
+ vec.emplace(vec.begin(), vec[0]);
694
+ EXPECT_EQ(vec[0], vec[1]);
695
+ vec.emplace(vec.begin() + i / 2, vec[i / 2]);
696
+ EXPECT_EQ(vec[i / 2], vec[i / 2 + 1]);
697
+ vec.emplace(vec.end() - 1, vec.back());
698
+ EXPECT_EQ(vec[vec.size() - 2], vec.back());
699
+ }
700
+ }
701
+
702
+ TEST(AliasingTest, InsertWithCount) {
703
+ for (size_t i = 1; i < 20; ++i) {
704
+ absl::InlinedVector<NotTriviallyDestructible, 10> vec;
705
+ for (size_t j = 0; j < i; ++j) {
706
+ vec.push_back(NotTriviallyDestructible(static_cast<int>(j)));
707
+ }
708
+ for (size_t n = 0; n < 5; ++n) {
709
+ // We use back where we can because it's guaranteed to become invalidated
710
+ vec.insert(vec.begin(), n, vec.back());
711
+ auto b = vec.begin();
712
+ EXPECT_TRUE(
713
+ std::all_of(b, b + n, [&vec](const NotTriviallyDestructible& x) {
714
+ return x == vec.back();
715
+ }));
716
+
717
+ auto m_idx = vec.size() / 2;
718
+ vec.insert(vec.begin() + m_idx, n, vec.back());
719
+ auto m = vec.begin() + m_idx;
720
+ EXPECT_TRUE(
721
+ std::all_of(m, m + n, [&vec](const NotTriviallyDestructible& x) {
722
+ return x == vec.back();
723
+ }));
724
+
725
+ // We want distinct values so the equality test is meaningful,
726
+ // vec[vec.size() - 1] is also almost always invalidated.
727
+ auto old_e = vec.size() - 1;
728
+ auto val = vec[old_e];
729
+ vec.insert(vec.end(), n, vec[old_e]);
730
+ auto e = vec.begin() + old_e;
731
+ EXPECT_TRUE(std::all_of(
732
+ e, e + n,
733
+ [&val](const NotTriviallyDestructible& x) { return x == val; }));
734
+ }
735
+ }
736
+ }
737
+
738
+ TEST(OverheadTest, Storage) {
739
+ // Check for size overhead.
740
+ // In particular, ensure that std::allocator doesn't cost anything to store.
741
+ // The union should be absorbing some of the allocation bookkeeping overhead
742
+ // in the larger vectors, leaving only the size_ field as overhead.
743
+
744
+ struct T { void* val; };
745
+ size_t expected_overhead = sizeof(T);
746
+
747
+ EXPECT_EQ((2 * expected_overhead),
748
+ sizeof(absl::InlinedVector<T, 1>) - sizeof(T[1]));
749
+ EXPECT_EQ(expected_overhead,
750
+ sizeof(absl::InlinedVector<T, 2>) - sizeof(T[2]));
751
+ EXPECT_EQ(expected_overhead,
752
+ sizeof(absl::InlinedVector<T, 3>) - sizeof(T[3]));
753
+ EXPECT_EQ(expected_overhead,
754
+ sizeof(absl::InlinedVector<T, 4>) - sizeof(T[4]));
755
+ EXPECT_EQ(expected_overhead,
756
+ sizeof(absl::InlinedVector<T, 5>) - sizeof(T[5]));
757
+ EXPECT_EQ(expected_overhead,
758
+ sizeof(absl::InlinedVector<T, 6>) - sizeof(T[6]));
759
+ EXPECT_EQ(expected_overhead,
760
+ sizeof(absl::InlinedVector<T, 7>) - sizeof(T[7]));
761
+ EXPECT_EQ(expected_overhead,
762
+ sizeof(absl::InlinedVector<T, 8>) - sizeof(T[8]));
763
+ }
764
+
765
+ TEST(IntVec, Clear) {
766
+ for (size_t len = 0; len < 20; len++) {
767
+ SCOPED_TRACE(len);
768
+ IntVec v;
769
+ Fill(&v, len);
770
+ v.clear();
771
+ EXPECT_EQ(0u, v.size());
772
+ EXPECT_EQ(v.begin(), v.end());
773
+ }
774
+ }
775
+
776
+ TEST(IntVec, Reserve) {
777
+ for (size_t len = 0; len < 20; len++) {
778
+ IntVec v;
779
+ Fill(&v, len);
780
+
781
+ for (size_t newlen = 0; newlen < 100; newlen++) {
782
+ const int* start_rep = v.data();
783
+ v.reserve(newlen);
784
+ const int* final_rep = v.data();
785
+ if (newlen <= len) {
786
+ EXPECT_EQ(start_rep, final_rep);
787
+ }
788
+ EXPECT_LE(newlen, v.capacity());
789
+
790
+ // Filling up to newlen should not change rep
791
+ while (v.size() < newlen) {
792
+ v.push_back(0);
793
+ }
794
+ EXPECT_EQ(final_rep, v.data());
795
+ }
796
+ }
797
+ }
798
+
799
+ TEST(StringVec, SelfRefPushBack) {
800
+ std::vector<std::string> std_v;
801
+ absl::InlinedVector<std::string, 4> v;
802
+ const std::string s = "A quite long string to ensure heap.";
803
+ std_v.push_back(s);
804
+ v.push_back(s);
805
+ for (int i = 0; i < 20; ++i) {
806
+ EXPECT_THAT(v, ElementsAreArray(std_v));
807
+
808
+ v.push_back(v.back());
809
+ std_v.push_back(std_v.back());
810
+ }
811
+ EXPECT_THAT(v, ElementsAreArray(std_v));
812
+ }
813
+
814
+ TEST(StringVec, SelfRefPushBackWithMove) {
815
+ std::vector<std::string> std_v;
816
+ absl::InlinedVector<std::string, 4> v;
817
+ const std::string s = "A quite long string to ensure heap.";
818
+ std_v.push_back(s);
819
+ v.push_back(s);
820
+ for (int i = 0; i < 20; ++i) {
821
+ EXPECT_EQ(v.back(), std_v.back());
822
+
823
+ v.push_back(std::move(v.back()));
824
+ std_v.push_back(std::move(std_v.back()));
825
+ }
826
+ EXPECT_EQ(v.back(), std_v.back());
827
+ }
828
+
829
+ TEST(StringVec, SelfMove) {
830
+ const std::string s = "A quite long string to ensure heap.";
831
+ for (int len = 0; len < 20; len++) {
832
+ SCOPED_TRACE(len);
833
+ absl::InlinedVector<std::string, 8> v;
834
+ for (int i = 0; i < len; ++i) {
835
+ SCOPED_TRACE(i);
836
+ v.push_back(s);
837
+ }
838
+ // Indirection necessary to avoid compiler warning.
839
+ v = std::move(*(&v));
840
+ // Ensure that the inlined vector is still in a valid state by copying it.
841
+ // We don't expect specific contents since a self-move results in an
842
+ // unspecified valid state.
843
+ std::vector<std::string> copy(v.begin(), v.end());
844
+ }
845
+ }
846
+
847
+ TEST(IntVec, Swap) {
848
+ for (size_t l1 = 0; l1 < 20; l1++) {
849
+ SCOPED_TRACE(l1);
850
+ for (size_t l2 = 0; l2 < 20; l2++) {
851
+ SCOPED_TRACE(l2);
852
+ IntVec a = Fill(l1, 0);
853
+ IntVec b = Fill(l2, 100);
854
+ {
855
+ using std::swap;
856
+ swap(a, b);
857
+ }
858
+ EXPECT_EQ(l1, b.size());
859
+ EXPECT_EQ(l2, a.size());
860
+ for (size_t i = 0; i < l1; i++) {
861
+ SCOPED_TRACE(i);
862
+ EXPECT_EQ(static_cast<int>(i), b[i]);
863
+ }
864
+ for (size_t i = 0; i < l2; i++) {
865
+ SCOPED_TRACE(i);
866
+ EXPECT_EQ(100 + static_cast<int>(i), a[i]);
867
+ }
868
+ }
869
+ }
870
+ }
871
+
872
+ TYPED_TEST_P(InstanceTest, Swap) {
873
+ using Instance = TypeParam;
874
+ using InstanceVec = absl::InlinedVector<Instance, 8>;
875
+ for (size_t l1 = 0; l1 < 20; l1++) {
876
+ SCOPED_TRACE(l1);
877
+ for (size_t l2 = 0; l2 < 20; l2++) {
878
+ SCOPED_TRACE(l2);
879
+ InstanceTracker tracker;
880
+ InstanceVec a, b;
881
+ const size_t inlined_capacity = a.capacity();
882
+ auto min_len = std::min(l1, l2);
883
+ auto max_len = std::max(l1, l2);
884
+ for (size_t i = 0; i < l1; i++)
885
+ a.push_back(Instance(static_cast<int>(i)));
886
+ for (size_t i = 0; i < l2; i++)
887
+ b.push_back(Instance(100 + static_cast<int>(i)));
888
+ EXPECT_EQ(tracker.instances(), static_cast<int>(l1 + l2));
889
+ tracker.ResetCopiesMovesSwaps();
890
+ {
891
+ using std::swap;
892
+ swap(a, b);
893
+ }
894
+ EXPECT_EQ(tracker.instances(), static_cast<int>(l1 + l2));
895
+ if (a.size() > inlined_capacity && b.size() > inlined_capacity) {
896
+ EXPECT_EQ(tracker.swaps(), 0); // Allocations are swapped.
897
+ EXPECT_EQ(tracker.moves(), 0);
898
+ } else if (a.size() <= inlined_capacity && b.size() <= inlined_capacity) {
899
+ EXPECT_EQ(tracker.swaps(), static_cast<int>(min_len));
900
+ EXPECT_EQ((tracker.moves() ? tracker.moves() : tracker.copies()),
901
+ static_cast<int>(max_len - min_len));
902
+ } else {
903
+ // One is allocated and the other isn't. The allocation is transferred
904
+ // without copying elements, and the inlined instances are copied/moved.
905
+ EXPECT_EQ(tracker.swaps(), 0);
906
+ EXPECT_EQ((tracker.moves() ? tracker.moves() : tracker.copies()),
907
+ static_cast<int>(min_len));
908
+ }
909
+
910
+ EXPECT_EQ(l1, b.size());
911
+ EXPECT_EQ(l2, a.size());
912
+ for (size_t i = 0; i < l1; i++) {
913
+ EXPECT_EQ(static_cast<int>(i), b[i].value());
914
+ }
915
+ for (size_t i = 0; i < l2; i++) {
916
+ EXPECT_EQ(100 + static_cast<int>(i), a[i].value());
917
+ }
918
+ }
919
+ }
920
+ }
921
+
922
+ TEST(IntVec, EqualAndNotEqual) {
923
+ IntVec a, b;
924
+ EXPECT_TRUE(a == b);
925
+ EXPECT_FALSE(a != b);
926
+
927
+ a.push_back(3);
928
+ EXPECT_FALSE(a == b);
929
+ EXPECT_TRUE(a != b);
930
+
931
+ b.push_back(3);
932
+ EXPECT_TRUE(a == b);
933
+ EXPECT_FALSE(a != b);
934
+
935
+ b.push_back(7);
936
+ EXPECT_FALSE(a == b);
937
+ EXPECT_TRUE(a != b);
938
+
939
+ a.push_back(6);
940
+ EXPECT_FALSE(a == b);
941
+ EXPECT_TRUE(a != b);
942
+
943
+ a.clear();
944
+ b.clear();
945
+ for (size_t i = 0; i < 100; i++) {
946
+ a.push_back(static_cast<int>(i));
947
+ b.push_back(static_cast<int>(i));
948
+ EXPECT_TRUE(a == b);
949
+ EXPECT_FALSE(a != b);
950
+
951
+ b[i] = b[i] + 1;
952
+ EXPECT_FALSE(a == b);
953
+ EXPECT_TRUE(a != b);
954
+
955
+ b[i] = b[i] - 1; // Back to before
956
+ EXPECT_TRUE(a == b);
957
+ EXPECT_FALSE(a != b);
958
+ }
959
+ }
960
+
961
+ TEST(IntVec, RelationalOps) {
962
+ IntVec a, b;
963
+ EXPECT_FALSE(a < b);
964
+ EXPECT_FALSE(b < a);
965
+ EXPECT_FALSE(a > b);
966
+ EXPECT_FALSE(b > a);
967
+ EXPECT_TRUE(a <= b);
968
+ EXPECT_TRUE(b <= a);
969
+ EXPECT_TRUE(a >= b);
970
+ EXPECT_TRUE(b >= a);
971
+ b.push_back(3);
972
+ EXPECT_TRUE(a < b);
973
+ EXPECT_FALSE(b < a);
974
+ EXPECT_FALSE(a > b);
975
+ EXPECT_TRUE(b > a);
976
+ EXPECT_TRUE(a <= b);
977
+ EXPECT_FALSE(b <= a);
978
+ EXPECT_FALSE(a >= b);
979
+ EXPECT_TRUE(b >= a);
980
+ }
981
+
982
+ TYPED_TEST_P(InstanceTest, CountConstructorsDestructors) {
983
+ using Instance = TypeParam;
984
+ using InstanceVec = absl::InlinedVector<Instance, 8>;
985
+ InstanceTracker tracker;
986
+ for (size_t len = 0; len < 20; len++) {
987
+ SCOPED_TRACE(len);
988
+ tracker.ResetCopiesMovesSwaps();
989
+
990
+ InstanceVec v;
991
+ const size_t inlined_capacity = v.capacity();
992
+ for (size_t i = 0; i < len; i++) {
993
+ v.push_back(Instance(static_cast<int>(i)));
994
+ }
995
+ EXPECT_EQ(tracker.instances(), static_cast<int>(len));
996
+ EXPECT_GE(tracker.copies() + tracker.moves(),
997
+ static_cast<int>(len)); // More due to reallocation.
998
+ tracker.ResetCopiesMovesSwaps();
999
+
1000
+ // Enlarging resize() must construct some objects
1001
+ tracker.ResetCopiesMovesSwaps();
1002
+ v.resize(len + 10, Instance(100));
1003
+ EXPECT_EQ(tracker.instances(), static_cast<int>(len) + 10);
1004
+ if (len <= inlined_capacity && len + 10 > inlined_capacity) {
1005
+ EXPECT_EQ(tracker.copies() + tracker.moves(), 10 + static_cast<int>(len));
1006
+ } else {
1007
+ // Only specify a minimum number of copies + moves. We don't want to
1008
+ // depend on the reallocation policy here.
1009
+ EXPECT_GE(tracker.copies() + tracker.moves(),
1010
+ 10); // More due to reallocation.
1011
+ }
1012
+
1013
+ // Shrinking resize() must destroy some objects
1014
+ tracker.ResetCopiesMovesSwaps();
1015
+ v.resize(len, Instance(100));
1016
+ EXPECT_EQ(tracker.instances(), static_cast<int>(len));
1017
+ EXPECT_EQ(tracker.copies(), 0);
1018
+ EXPECT_EQ(tracker.moves(), 0);
1019
+
1020
+ // reserve() must not increase the number of initialized objects
1021
+ SCOPED_TRACE("reserve");
1022
+ v.reserve(len + 1000);
1023
+ EXPECT_EQ(tracker.instances(), static_cast<int>(len));
1024
+ EXPECT_EQ(tracker.copies() + tracker.moves(), static_cast<int>(len));
1025
+
1026
+ // pop_back() and erase() must destroy one object
1027
+ if (len > 0) {
1028
+ tracker.ResetCopiesMovesSwaps();
1029
+ v.pop_back();
1030
+ EXPECT_EQ(tracker.instances(), static_cast<int>(len) - 1);
1031
+ EXPECT_EQ(tracker.copies(), 0);
1032
+ EXPECT_EQ(tracker.moves(), 0);
1033
+
1034
+ if (!v.empty()) {
1035
+ tracker.ResetCopiesMovesSwaps();
1036
+ v.erase(v.begin());
1037
+ EXPECT_EQ(tracker.instances(), static_cast<int>(len) - 2);
1038
+ EXPECT_EQ(tracker.copies() + tracker.moves(),
1039
+ static_cast<int>(len) - 2);
1040
+ }
1041
+ }
1042
+
1043
+ tracker.ResetCopiesMovesSwaps();
1044
+ int instances_before_empty_erase = tracker.instances();
1045
+ v.erase(v.begin(), v.begin());
1046
+ EXPECT_EQ(tracker.instances(), instances_before_empty_erase);
1047
+ EXPECT_EQ(tracker.copies() + tracker.moves(), 0);
1048
+ }
1049
+ }
1050
+
1051
+ TYPED_TEST_P(InstanceTest, CountConstructorsDestructorsOnCopyConstruction) {
1052
+ using Instance = TypeParam;
1053
+ using InstanceVec = absl::InlinedVector<Instance, 8>;
1054
+ InstanceTracker tracker;
1055
+ for (int len = 0; len < 20; len++) {
1056
+ SCOPED_TRACE(len);
1057
+ tracker.ResetCopiesMovesSwaps();
1058
+
1059
+ InstanceVec v;
1060
+ for (int i = 0; i < len; i++) {
1061
+ v.push_back(Instance(i));
1062
+ }
1063
+ EXPECT_EQ(tracker.instances(), len);
1064
+ EXPECT_GE(tracker.copies() + tracker.moves(),
1065
+ len); // More due to reallocation.
1066
+ tracker.ResetCopiesMovesSwaps();
1067
+ { // Copy constructor should create 'len' more instances.
1068
+ InstanceVec v_copy(v);
1069
+ EXPECT_EQ(tracker.instances(), len + len);
1070
+ EXPECT_EQ(tracker.copies(), len);
1071
+ EXPECT_EQ(tracker.moves(), 0);
1072
+ }
1073
+ EXPECT_EQ(tracker.instances(), len);
1074
+ }
1075
+ }
1076
+
1077
+ TYPED_TEST_P(InstanceTest, CountConstructorsDestructorsOnMoveConstruction) {
1078
+ using Instance = TypeParam;
1079
+ using InstanceVec = absl::InlinedVector<Instance, 8>;
1080
+ InstanceTracker tracker;
1081
+ for (int len = 0; len < 20; len++) {
1082
+ SCOPED_TRACE(len);
1083
+ tracker.ResetCopiesMovesSwaps();
1084
+
1085
+ InstanceVec v;
1086
+ const size_t inlined_capacity = v.capacity();
1087
+ for (int i = 0; i < len; i++) {
1088
+ v.push_back(Instance(i));
1089
+ }
1090
+ EXPECT_EQ(tracker.instances(), len);
1091
+ EXPECT_GE(tracker.copies() + tracker.moves(),
1092
+ len); // More due to reallocation.
1093
+ tracker.ResetCopiesMovesSwaps();
1094
+ {
1095
+ InstanceVec v_copy(std::move(v));
1096
+ if (static_cast<size_t>(len) > inlined_capacity) {
1097
+ // Allocation is moved as a whole.
1098
+ EXPECT_EQ(tracker.instances(), len);
1099
+ EXPECT_EQ(tracker.live_instances(), len);
1100
+ // Tests an implementation detail, don't rely on this in your code.
1101
+ EXPECT_EQ(v.size(), 0u); // NOLINT misc-use-after-move
1102
+ EXPECT_EQ(tracker.copies(), 0);
1103
+ EXPECT_EQ(tracker.moves(), 0);
1104
+ } else {
1105
+ EXPECT_EQ(tracker.instances(), len + len);
1106
+ if (Instance::supports_move()) {
1107
+ EXPECT_EQ(tracker.live_instances(), len);
1108
+ EXPECT_EQ(tracker.copies(), 0);
1109
+ EXPECT_EQ(tracker.moves(), len);
1110
+ } else {
1111
+ EXPECT_EQ(tracker.live_instances(), len + len);
1112
+ EXPECT_EQ(tracker.copies(), len);
1113
+ EXPECT_EQ(tracker.moves(), 0);
1114
+ }
1115
+ }
1116
+ EXPECT_EQ(tracker.swaps(), 0);
1117
+ }
1118
+ }
1119
+ }
1120
+
1121
+ TYPED_TEST_P(InstanceTest, CountConstructorsDestructorsOnAssignment) {
1122
+ using Instance = TypeParam;
1123
+ using InstanceVec = absl::InlinedVector<Instance, 8>;
1124
+ InstanceTracker tracker;
1125
+ for (int len = 0; len < 20; len++) {
1126
+ SCOPED_TRACE(len);
1127
+ for (int longorshort = 0; longorshort <= 1; ++longorshort) {
1128
+ SCOPED_TRACE(longorshort);
1129
+ tracker.ResetCopiesMovesSwaps();
1130
+
1131
+ InstanceVec longer, shorter;
1132
+ for (int i = 0; i < len; i++) {
1133
+ longer.push_back(Instance(i));
1134
+ shorter.push_back(Instance(i));
1135
+ }
1136
+ longer.push_back(Instance(len));
1137
+ EXPECT_EQ(tracker.instances(), len + len + 1);
1138
+ EXPECT_GE(tracker.copies() + tracker.moves(),
1139
+ len + len + 1); // More due to reallocation.
1140
+
1141
+ tracker.ResetCopiesMovesSwaps();
1142
+ if (longorshort) {
1143
+ shorter = longer;
1144
+ EXPECT_EQ(tracker.instances(), (len + 1) + (len + 1));
1145
+ EXPECT_GE(tracker.copies() + tracker.moves(),
1146
+ len + 1); // More due to reallocation.
1147
+ } else {
1148
+ longer = shorter;
1149
+ EXPECT_EQ(tracker.instances(), len + len);
1150
+ EXPECT_EQ(tracker.copies() + tracker.moves(), len);
1151
+ }
1152
+ }
1153
+ }
1154
+ }
1155
+
1156
+ TYPED_TEST_P(InstanceTest, CountConstructorsDestructorsOnMoveAssignment) {
1157
+ using Instance = TypeParam;
1158
+ using InstanceVec = absl::InlinedVector<Instance, 8>;
1159
+ InstanceTracker tracker;
1160
+ for (int len = 0; len < 20; len++) {
1161
+ SCOPED_TRACE(len);
1162
+ for (int longorshort = 0; longorshort <= 1; ++longorshort) {
1163
+ SCOPED_TRACE(longorshort);
1164
+ tracker.ResetCopiesMovesSwaps();
1165
+
1166
+ InstanceVec longer, shorter;
1167
+ const size_t inlined_capacity = longer.capacity();
1168
+ for (int i = 0; i < len; i++) {
1169
+ longer.push_back(Instance(i));
1170
+ shorter.push_back(Instance(i));
1171
+ }
1172
+ longer.push_back(Instance(len));
1173
+ EXPECT_EQ(tracker.instances(), len + len + 1);
1174
+ EXPECT_GE(tracker.copies() + tracker.moves(),
1175
+ len + len + 1); // More due to reallocation.
1176
+
1177
+ tracker.ResetCopiesMovesSwaps();
1178
+ int src_len;
1179
+ if (longorshort) {
1180
+ src_len = len + 1;
1181
+ shorter = std::move(longer);
1182
+ } else {
1183
+ src_len = len;
1184
+ longer = std::move(shorter);
1185
+ }
1186
+ if (static_cast<size_t>(src_len) > inlined_capacity) {
1187
+ // Allocation moved as a whole.
1188
+ EXPECT_EQ(tracker.instances(), src_len);
1189
+ EXPECT_EQ(tracker.live_instances(), src_len);
1190
+ EXPECT_EQ(tracker.copies(), 0);
1191
+ EXPECT_EQ(tracker.moves(), 0);
1192
+ } else {
1193
+ // Elements are all copied.
1194
+ EXPECT_EQ(tracker.instances(), src_len + src_len);
1195
+ if (Instance::supports_move()) {
1196
+ EXPECT_EQ(tracker.copies(), 0);
1197
+ EXPECT_EQ(tracker.moves(), src_len);
1198
+ EXPECT_EQ(tracker.live_instances(), src_len);
1199
+ } else {
1200
+ EXPECT_EQ(tracker.copies(), src_len);
1201
+ EXPECT_EQ(tracker.moves(), 0);
1202
+ EXPECT_EQ(tracker.live_instances(), src_len + src_len);
1203
+ }
1204
+ }
1205
+ EXPECT_EQ(tracker.swaps(), 0);
1206
+ }
1207
+ }
1208
+ }
1209
+
1210
+ TEST(CountElemAssign, SimpleTypeWithInlineBacking) {
1211
+ const size_t inlined_capacity = absl::InlinedVector<int, 2>().capacity();
1212
+
1213
+ for (size_t original_size = 0; original_size <= 5; ++original_size) {
1214
+ SCOPED_TRACE(original_size);
1215
+ // Original contents are [12345, 12345, ...]
1216
+ std::vector<int> original_contents(original_size, 12345);
1217
+
1218
+ absl::InlinedVector<int, 2> v(original_contents.begin(),
1219
+ original_contents.end());
1220
+ v.assign(2, 123);
1221
+ EXPECT_THAT(v, AllOf(SizeIs(2u), ElementsAre(123, 123)));
1222
+ if (original_size <= inlined_capacity) {
1223
+ // If the original had inline backing, it should stay inline.
1224
+ EXPECT_EQ(v.capacity(), inlined_capacity);
1225
+ }
1226
+ }
1227
+ }
1228
+
1229
+ TEST(CountElemAssign, SimpleTypeWithAllocation) {
1230
+ for (size_t original_size = 0; original_size <= 5; ++original_size) {
1231
+ SCOPED_TRACE(original_size);
1232
+ // Original contents are [12345, 12345, ...]
1233
+ std::vector<int> original_contents(original_size, 12345);
1234
+
1235
+ absl::InlinedVector<int, 2> v(original_contents.begin(),
1236
+ original_contents.end());
1237
+ v.assign(3, 123);
1238
+ EXPECT_THAT(v, AllOf(SizeIs(3u), ElementsAre(123, 123, 123)));
1239
+ EXPECT_LE(v.size(), v.capacity());
1240
+ }
1241
+ }
1242
+
1243
+ TYPED_TEST_P(InstanceTest, CountElemAssignInlineBacking) {
1244
+ using Instance = TypeParam;
1245
+ for (size_t original_size = 0; original_size <= 5; ++original_size) {
1246
+ SCOPED_TRACE(original_size);
1247
+ // Original contents are [12345, 12345, ...]
1248
+ std::vector<Instance> original_contents(original_size, Instance(12345));
1249
+
1250
+ absl::InlinedVector<Instance, 2> v(original_contents.begin(),
1251
+ original_contents.end());
1252
+ v.assign(2, Instance(123));
1253
+ EXPECT_THAT(v, AllOf(SizeIs(2u), ElementsAre(ValueIs(123), ValueIs(123))));
1254
+ if (original_size <= 2) {
1255
+ // If the original had inline backing, it should stay inline.
1256
+ EXPECT_EQ(2u, v.capacity());
1257
+ }
1258
+ }
1259
+ }
1260
+
1261
+ template <typename Instance>
1262
+ void InstanceCountElemAssignWithAllocationTest() {
1263
+ for (size_t original_size = 0; original_size <= 5; ++original_size) {
1264
+ SCOPED_TRACE(original_size);
1265
+ // Original contents are [12345, 12345, ...]
1266
+ std::vector<Instance> original_contents(original_size, Instance(12345));
1267
+
1268
+ absl::InlinedVector<Instance, 2> v(original_contents.begin(),
1269
+ original_contents.end());
1270
+ v.assign(3, Instance(123));
1271
+ EXPECT_THAT(v, AllOf(SizeIs(3u), ElementsAre(ValueIs(123), ValueIs(123),
1272
+ ValueIs(123))));
1273
+ EXPECT_LE(v.size(), v.capacity());
1274
+ }
1275
+ }
1276
+ TEST(CountElemAssign, WithAllocationCopyableInstance) {
1277
+ InstanceCountElemAssignWithAllocationTest<CopyableOnlyInstance>();
1278
+ }
1279
+ TEST(CountElemAssign, WithAllocationCopyableMovableInstance) {
1280
+ InstanceCountElemAssignWithAllocationTest<CopyableMovableInstance>();
1281
+ }
1282
+
1283
+ TEST(RangedConstructor, SimpleType) {
1284
+ std::vector<int> source_v = {4, 5, 6};
1285
+ // First try to fit in inline backing
1286
+ absl::InlinedVector<int, 4> v(source_v.begin(), source_v.end());
1287
+ EXPECT_EQ(3u, v.size());
1288
+ EXPECT_EQ(4u,
1289
+ v.capacity()); // Indication that we're still on inlined storage
1290
+ EXPECT_EQ(4, v[0]);
1291
+ EXPECT_EQ(5, v[1]);
1292
+ EXPECT_EQ(6, v[2]);
1293
+
1294
+ // Now, force a re-allocate
1295
+ absl::InlinedVector<int, 2> realloc_v(source_v.begin(), source_v.end());
1296
+ EXPECT_EQ(3u, realloc_v.size());
1297
+ EXPECT_LT(2u, realloc_v.capacity());
1298
+ EXPECT_EQ(4, realloc_v[0]);
1299
+ EXPECT_EQ(5, realloc_v[1]);
1300
+ EXPECT_EQ(6, realloc_v[2]);
1301
+ }
1302
+
1303
+ // Test for ranged constructors using Instance as the element type and
1304
+ // SourceContainer as the source container type.
1305
+ template <typename Instance, typename SourceContainer, int inlined_capacity>
1306
+ void InstanceRangedConstructorTestForContainer() {
1307
+ InstanceTracker tracker;
1308
+ SourceContainer source_v = {Instance(0), Instance(1)};
1309
+ tracker.ResetCopiesMovesSwaps();
1310
+ absl::InlinedVector<Instance, inlined_capacity> v(source_v.begin(),
1311
+ source_v.end());
1312
+ EXPECT_EQ(2u, v.size());
1313
+ EXPECT_LT(1u, v.capacity());
1314
+ EXPECT_EQ(0, v[0].value());
1315
+ EXPECT_EQ(1, v[1].value());
1316
+ EXPECT_EQ(tracker.copies(), 2);
1317
+ EXPECT_EQ(tracker.moves(), 0);
1318
+ }
1319
+
1320
+ template <typename Instance, int inlined_capacity>
1321
+ void InstanceRangedConstructorTestWithCapacity() {
1322
+ // Test with const and non-const, random access and non-random-access sources.
1323
+ // TODO(bsamwel): Test with an input iterator source.
1324
+ {
1325
+ SCOPED_TRACE("std::list");
1326
+ InstanceRangedConstructorTestForContainer<Instance, std::list<Instance>,
1327
+ inlined_capacity>();
1328
+ {
1329
+ SCOPED_TRACE("const std::list");
1330
+ InstanceRangedConstructorTestForContainer<
1331
+ Instance, const std::list<Instance>, inlined_capacity>();
1332
+ }
1333
+ {
1334
+ SCOPED_TRACE("std::vector");
1335
+ InstanceRangedConstructorTestForContainer<Instance, std::vector<Instance>,
1336
+ inlined_capacity>();
1337
+ }
1338
+ {
1339
+ SCOPED_TRACE("const std::vector");
1340
+ InstanceRangedConstructorTestForContainer<
1341
+ Instance, const std::vector<Instance>, inlined_capacity>();
1342
+ }
1343
+ }
1344
+ }
1345
+
1346
+ TYPED_TEST_P(InstanceTest, RangedConstructor) {
1347
+ using Instance = TypeParam;
1348
+ SCOPED_TRACE("capacity=1");
1349
+ InstanceRangedConstructorTestWithCapacity<Instance, 1>();
1350
+ SCOPED_TRACE("capacity=2");
1351
+ InstanceRangedConstructorTestWithCapacity<Instance, 2>();
1352
+ }
1353
+
1354
+ TEST(RangedConstructor, ElementsAreConstructed) {
1355
+ std::vector<std::string> source_v = {"cat", "dog"};
1356
+
1357
+ // Force expansion and re-allocation of v. Ensures that when the vector is
1358
+ // expanded that new elements are constructed.
1359
+ absl::InlinedVector<std::string, 1> v(source_v.begin(), source_v.end());
1360
+ EXPECT_EQ("cat", v[0]);
1361
+ EXPECT_EQ("dog", v[1]);
1362
+ }
1363
+
1364
+ TEST(RangedAssign, SimpleType) {
1365
+ const size_t inlined_capacity = absl::InlinedVector<int, 3>().capacity();
1366
+
1367
+ // Test for all combinations of original sizes (empty and non-empty inline,
1368
+ // and out of line) and target sizes.
1369
+ for (size_t original_size = 0; original_size <= 5; ++original_size) {
1370
+ SCOPED_TRACE(original_size);
1371
+ // Original contents are [12345, 12345, ...]
1372
+ std::vector<int> original_contents(original_size, 12345);
1373
+
1374
+ for (size_t target_size = 0; target_size <= 5; ++target_size) {
1375
+ SCOPED_TRACE(target_size);
1376
+
1377
+ // New contents are [3, 4, ...]
1378
+ std::vector<int> new_contents;
1379
+ for (size_t i = 0; i < target_size; ++i) {
1380
+ new_contents.push_back(static_cast<int>(i + 3));
1381
+ }
1382
+
1383
+ absl::InlinedVector<int, 3> v(original_contents.begin(),
1384
+ original_contents.end());
1385
+ v.assign(new_contents.begin(), new_contents.end());
1386
+
1387
+ EXPECT_EQ(new_contents.size(), v.size());
1388
+ EXPECT_LE(new_contents.size(), v.capacity());
1389
+ if (target_size <= inlined_capacity &&
1390
+ original_size <= inlined_capacity) {
1391
+ // Storage should stay inline when target size is small.
1392
+ EXPECT_EQ(v.capacity(), inlined_capacity);
1393
+ }
1394
+ EXPECT_THAT(v, ElementsAreArray(new_contents));
1395
+ }
1396
+ }
1397
+ }
1398
+
1399
+ // Returns true if lhs and rhs have the same value.
1400
+ template <typename Instance>
1401
+ static bool InstanceValuesEqual(const Instance& lhs, const Instance& rhs) {
1402
+ return lhs.value() == rhs.value();
1403
+ }
1404
+
1405
+ // Test for ranged assign() using Instance as the element type and
1406
+ // SourceContainer as the source container type.
1407
+ template <typename Instance, typename SourceContainer>
1408
+ void InstanceRangedAssignTestForContainer() {
1409
+ // Test for all combinations of original sizes (empty and non-empty inline,
1410
+ // and out of line) and target sizes.
1411
+ for (size_t original_size = 0; original_size <= 5; ++original_size) {
1412
+ SCOPED_TRACE(original_size);
1413
+ // Original contents are [12345, 12345, ...]
1414
+ std::vector<Instance> original_contents(original_size, Instance(12345));
1415
+
1416
+ for (size_t target_size = 0; target_size <= 5; ++target_size) {
1417
+ SCOPED_TRACE(target_size);
1418
+
1419
+ // New contents are [3, 4, ...]
1420
+ // Generate data using a non-const container, because SourceContainer
1421
+ // itself may be const.
1422
+ // TODO(bsamwel): Test with an input iterator.
1423
+ std::vector<Instance> new_contents_in;
1424
+ for (size_t i = 0; i < target_size; ++i) {
1425
+ new_contents_in.push_back(Instance(static_cast<int>(i) + 3));
1426
+ }
1427
+ SourceContainer new_contents(new_contents_in.begin(),
1428
+ new_contents_in.end());
1429
+
1430
+ absl::InlinedVector<Instance, 3> v(original_contents.begin(),
1431
+ original_contents.end());
1432
+ v.assign(new_contents.begin(), new_contents.end());
1433
+
1434
+ EXPECT_EQ(new_contents.size(), v.size());
1435
+ EXPECT_LE(new_contents.size(), v.capacity());
1436
+ if (target_size <= 3 && original_size <= 3) {
1437
+ // Storage should stay inline when target size is small.
1438
+ EXPECT_EQ(3u, v.capacity());
1439
+ }
1440
+ EXPECT_TRUE(std::equal(v.begin(), v.end(), new_contents.begin(),
1441
+ InstanceValuesEqual<Instance>));
1442
+ }
1443
+ }
1444
+ }
1445
+
1446
+ TYPED_TEST_P(InstanceTest, RangedAssign) {
1447
+ using Instance = TypeParam;
1448
+ // Test with const and non-const, random access and non-random-access sources.
1449
+ // TODO(bsamwel): Test with an input iterator source.
1450
+ SCOPED_TRACE("std::list");
1451
+ InstanceRangedAssignTestForContainer<Instance, std::list<Instance>>();
1452
+ SCOPED_TRACE("const std::list");
1453
+ InstanceRangedAssignTestForContainer<Instance, const std::list<Instance>>();
1454
+ SCOPED_TRACE("std::vector");
1455
+ InstanceRangedAssignTestForContainer<Instance, std::vector<Instance>>();
1456
+ SCOPED_TRACE("const std::vector");
1457
+ InstanceRangedAssignTestForContainer<Instance, const std::vector<Instance>>();
1458
+ }
1459
+
1460
+ TEST(InitializerListConstructor, SimpleTypeWithInlineBacking) {
1461
+ EXPECT_THAT((absl::InlinedVector<int, 4>{4, 5, 6}),
1462
+ AllOf(SizeIs(3u), CapacityIs(4u), ElementsAre(4, 5, 6)));
1463
+ }
1464
+
1465
+ TEST(InitializerListConstructor, SimpleTypeWithReallocationRequired) {
1466
+ EXPECT_THAT((absl::InlinedVector<int, 2>{4, 5, 6}),
1467
+ AllOf(SizeIs(3u), CapacityIs(Gt(2u)), ElementsAre(4, 5, 6)));
1468
+ }
1469
+
1470
+ TEST(InitializerListConstructor, DisparateTypesInList) {
1471
+ EXPECT_THAT((absl::InlinedVector<int, 2>{-7, 8ULL}), ElementsAre(-7, 8));
1472
+
1473
+ EXPECT_THAT((absl::InlinedVector<std::string, 2>{"foo", std::string("bar")}),
1474
+ ElementsAre("foo", "bar"));
1475
+ }
1476
+
1477
+ TEST(InitializerListConstructor, ComplexTypeWithInlineBacking) {
1478
+ const size_t inlined_capacity =
1479
+ absl::InlinedVector<CopyableMovableInstance, 1>().capacity();
1480
+ EXPECT_THAT(
1481
+ (absl::InlinedVector<CopyableMovableInstance, 1>{
1482
+ CopyableMovableInstance(0)}),
1483
+ AllOf(SizeIs(1u), CapacityIs(inlined_capacity), ElementsAre(ValueIs(0))));
1484
+ }
1485
+
1486
+ TEST(InitializerListConstructor, ComplexTypeWithReallocationRequired) {
1487
+ EXPECT_THAT((absl::InlinedVector<CopyableMovableInstance, 1>{
1488
+ CopyableMovableInstance(0), CopyableMovableInstance(1)}),
1489
+ AllOf(SizeIs(2u), CapacityIs(Gt(1u)),
1490
+ ElementsAre(ValueIs(0), ValueIs(1))));
1491
+ }
1492
+
1493
+ TEST(InitializerListAssign, SimpleTypeFitsInlineBacking) {
1494
+ for (size_t original_size = 0; original_size <= 4; ++original_size) {
1495
+ SCOPED_TRACE(original_size);
1496
+
1497
+ absl::InlinedVector<int, 2> v1(original_size, 12345);
1498
+ const size_t original_capacity_v1 = v1.capacity();
1499
+ v1.assign({3});
1500
+ EXPECT_THAT(v1, AllOf(SizeIs(1u), CapacityIs(original_capacity_v1),
1501
+ ElementsAre(3)));
1502
+
1503
+ absl::InlinedVector<int, 2> v2(original_size, 12345);
1504
+ const size_t original_capacity_v2 = v2.capacity();
1505
+ v2 = {3};
1506
+ EXPECT_THAT(v2, AllOf(SizeIs(1u), CapacityIs(original_capacity_v2),
1507
+ ElementsAre(3)));
1508
+ }
1509
+ }
1510
+
1511
+ TEST(InitializerListAssign, SimpleTypeDoesNotFitInlineBacking) {
1512
+ for (size_t original_size = 0; original_size <= 4; ++original_size) {
1513
+ SCOPED_TRACE(original_size);
1514
+ absl::InlinedVector<int, 2> v1(original_size, 12345);
1515
+ v1.assign({3, 4, 5});
1516
+ EXPECT_THAT(v1, AllOf(SizeIs(3u), ElementsAre(3, 4, 5)));
1517
+ EXPECT_LE(3u, v1.capacity());
1518
+
1519
+ absl::InlinedVector<int, 2> v2(original_size, 12345);
1520
+ v2 = {3, 4, 5};
1521
+ EXPECT_THAT(v2, AllOf(SizeIs(3u), ElementsAre(3, 4, 5)));
1522
+ EXPECT_LE(3u, v2.capacity());
1523
+ }
1524
+ }
1525
+
1526
+ TEST(InitializerListAssign, DisparateTypesInList) {
1527
+ absl::InlinedVector<int, 2> v_int1;
1528
+ v_int1.assign({-7, 8ULL});
1529
+ EXPECT_THAT(v_int1, ElementsAre(-7, 8));
1530
+
1531
+ absl::InlinedVector<int, 2> v_int2;
1532
+ v_int2 = {-7, 8ULL};
1533
+ EXPECT_THAT(v_int2, ElementsAre(-7, 8));
1534
+
1535
+ absl::InlinedVector<std::string, 2> v_string1;
1536
+ v_string1.assign({"foo", std::string("bar")});
1537
+ EXPECT_THAT(v_string1, ElementsAre("foo", "bar"));
1538
+
1539
+ absl::InlinedVector<std::string, 2> v_string2;
1540
+ v_string2 = {"foo", std::string("bar")};
1541
+ EXPECT_THAT(v_string2, ElementsAre("foo", "bar"));
1542
+ }
1543
+
1544
+ TYPED_TEST_P(InstanceTest, InitializerListAssign) {
1545
+ using Instance = TypeParam;
1546
+ for (size_t original_size = 0; original_size <= 4; ++original_size) {
1547
+ SCOPED_TRACE(original_size);
1548
+ absl::InlinedVector<Instance, 2> v(original_size, Instance(12345));
1549
+ const size_t original_capacity = v.capacity();
1550
+ v.assign({Instance(3)});
1551
+ EXPECT_THAT(v, AllOf(SizeIs(1u), CapacityIs(original_capacity),
1552
+ ElementsAre(ValueIs(3))));
1553
+ }
1554
+ for (size_t original_size = 0; original_size <= 4; ++original_size) {
1555
+ SCOPED_TRACE(original_size);
1556
+ absl::InlinedVector<Instance, 2> v(original_size, Instance(12345));
1557
+ v.assign({Instance(3), Instance(4), Instance(5)});
1558
+ EXPECT_THAT(
1559
+ v, AllOf(SizeIs(3u), ElementsAre(ValueIs(3), ValueIs(4), ValueIs(5))));
1560
+ EXPECT_LE(3u, v.capacity());
1561
+ }
1562
+ }
1563
+
1564
+ REGISTER_TYPED_TEST_SUITE_P(InstanceTest, Swap, CountConstructorsDestructors,
1565
+ CountConstructorsDestructorsOnCopyConstruction,
1566
+ CountConstructorsDestructorsOnMoveConstruction,
1567
+ CountConstructorsDestructorsOnAssignment,
1568
+ CountConstructorsDestructorsOnMoveAssignment,
1569
+ CountElemAssignInlineBacking, RangedConstructor,
1570
+ RangedAssign, InitializerListAssign);
1571
+
1572
+ using InstanceTypes =
1573
+ ::testing::Types<CopyableOnlyInstance, CopyableMovableInstance>;
1574
+ INSTANTIATE_TYPED_TEST_SUITE_P(InstanceTestOnTypes, InstanceTest,
1575
+ InstanceTypes);
1576
+
1577
+ TEST(DynamicVec, DynamicVecCompiles) {
1578
+ DynamicVec v;
1579
+ (void)v;
1580
+ }
1581
+
1582
+ TEST(AllocatorSupportTest, Constructors) {
1583
+ using MyAlloc = CountingAllocator<int>;
1584
+ using AllocVec = absl::InlinedVector<int, 4, MyAlloc>;
1585
+ const int ia[] = {0, 1, 2, 3, 4, 5, 6, 7};
1586
+ int64_t allocated = 0;
1587
+ MyAlloc alloc(&allocated);
1588
+ { AllocVec ABSL_ATTRIBUTE_UNUSED v; }
1589
+ { AllocVec ABSL_ATTRIBUTE_UNUSED v(alloc); }
1590
+ { AllocVec ABSL_ATTRIBUTE_UNUSED v(ia, ia + ABSL_ARRAYSIZE(ia), alloc); }
1591
+ { AllocVec ABSL_ATTRIBUTE_UNUSED v({1, 2, 3}, alloc); }
1592
+
1593
+ AllocVec v2;
1594
+ { AllocVec ABSL_ATTRIBUTE_UNUSED v(v2, alloc); }
1595
+ { AllocVec ABSL_ATTRIBUTE_UNUSED v(std::move(v2), alloc); }
1596
+ }
1597
+
1598
+ TEST(AllocatorSupportTest, CountAllocations) {
1599
+ using MyAlloc = CountingAllocator<int>;
1600
+ using AllocVec = absl::InlinedVector<int, 4, MyAlloc>;
1601
+ const int ia[] = {0, 1, 2, 3, 4, 5, 6, 7};
1602
+ int64_t allocated = 0;
1603
+ MyAlloc alloc(&allocated);
1604
+ {
1605
+ AllocVec ABSL_ATTRIBUTE_UNUSED v(ia, ia + 4, alloc);
1606
+ EXPECT_THAT(allocated, Eq(0));
1607
+ }
1608
+ EXPECT_THAT(allocated, Eq(0));
1609
+ {
1610
+ AllocVec ABSL_ATTRIBUTE_UNUSED v(ia, ia + ABSL_ARRAYSIZE(ia), alloc);
1611
+ EXPECT_THAT(allocated, Eq(static_cast<int64_t>(v.size() * sizeof(int))));
1612
+ }
1613
+ EXPECT_THAT(allocated, Eq(0));
1614
+ {
1615
+ AllocVec v(4, 1, alloc);
1616
+ EXPECT_THAT(allocated, Eq(0));
1617
+
1618
+ int64_t allocated2 = 0;
1619
+ MyAlloc alloc2(&allocated2);
1620
+ AllocVec v2(v, alloc2);
1621
+ EXPECT_THAT(allocated2, Eq(0));
1622
+
1623
+ int64_t allocated3 = 0;
1624
+ MyAlloc alloc3(&allocated3);
1625
+ AllocVec v3(std::move(v), alloc3);
1626
+ EXPECT_THAT(allocated3, Eq(0));
1627
+ }
1628
+ EXPECT_THAT(allocated, 0);
1629
+ {
1630
+ AllocVec v(8, 2, alloc);
1631
+ EXPECT_THAT(allocated, Eq(static_cast<int64_t>(v.size() * sizeof(int))));
1632
+
1633
+ int64_t allocated2 = 0;
1634
+ MyAlloc alloc2(&allocated2);
1635
+ AllocVec v2(v, alloc2);
1636
+ EXPECT_THAT(allocated2, Eq(static_cast<int64_t>(v2.size() * sizeof(int))));
1637
+
1638
+ int64_t allocated3 = 0;
1639
+ MyAlloc alloc3(&allocated3);
1640
+ AllocVec v3(std::move(v), alloc3);
1641
+ EXPECT_THAT(allocated3, Eq(static_cast<int64_t>(v3.size() * sizeof(int))));
1642
+ }
1643
+ EXPECT_EQ(allocated, 0);
1644
+ {
1645
+ // Test shrink_to_fit deallocations.
1646
+ AllocVec v(8, 2, alloc);
1647
+ EXPECT_EQ(allocated, static_cast<int64_t>(8 * sizeof(int)));
1648
+ v.resize(5);
1649
+ EXPECT_EQ(allocated, static_cast<int64_t>(8 * sizeof(int)));
1650
+ v.shrink_to_fit();
1651
+ EXPECT_EQ(allocated, static_cast<int64_t>(5 * sizeof(int)));
1652
+ v.resize(4);
1653
+ EXPECT_EQ(allocated, static_cast<int64_t>(5 * sizeof(int)));
1654
+ v.shrink_to_fit();
1655
+ EXPECT_EQ(allocated, 0);
1656
+ }
1657
+ }
1658
+
1659
+ TEST(AllocatorSupportTest, SwapBothAllocated) {
1660
+ using MyAlloc = CountingAllocator<int>;
1661
+ using AllocVec = absl::InlinedVector<int, 4, MyAlloc>;
1662
+ int64_t allocated1 = 0;
1663
+ int64_t allocated2 = 0;
1664
+ {
1665
+ const int ia1[] = {0, 1, 2, 3, 4, 5, 6, 7};
1666
+ const int ia2[] = {0, 1, 2, 3, 4, 5, 6, 7, 8};
1667
+ MyAlloc a1(&allocated1);
1668
+ MyAlloc a2(&allocated2);
1669
+ AllocVec v1(ia1, ia1 + ABSL_ARRAYSIZE(ia1), a1);
1670
+ AllocVec v2(ia2, ia2 + ABSL_ARRAYSIZE(ia2), a2);
1671
+ EXPECT_LT(v1.capacity(), v2.capacity());
1672
+ EXPECT_THAT(allocated1,
1673
+ Eq(static_cast<int64_t>(v1.capacity() * sizeof(int))));
1674
+ EXPECT_THAT(allocated2,
1675
+ Eq(static_cast<int64_t>(v2.capacity() * sizeof(int))));
1676
+ v1.swap(v2);
1677
+ EXPECT_THAT(v1, ElementsAreArray(ia2));
1678
+ EXPECT_THAT(v2, ElementsAreArray(ia1));
1679
+ EXPECT_THAT(allocated1,
1680
+ Eq(static_cast<int64_t>(v2.capacity() * sizeof(int))));
1681
+ EXPECT_THAT(allocated2,
1682
+ Eq(static_cast<int64_t>(v1.capacity() * sizeof(int))));
1683
+ }
1684
+ EXPECT_THAT(allocated1, 0);
1685
+ EXPECT_THAT(allocated2, 0);
1686
+ }
1687
+
1688
+ TEST(AllocatorSupportTest, SwapOneAllocated) {
1689
+ using MyAlloc = CountingAllocator<int>;
1690
+ using AllocVec = absl::InlinedVector<int, 4, MyAlloc>;
1691
+ int64_t allocated1 = 0;
1692
+ int64_t allocated2 = 0;
1693
+ {
1694
+ const int ia1[] = {0, 1, 2, 3, 4, 5, 6, 7};
1695
+ const int ia2[] = {0, 1, 2, 3};
1696
+ MyAlloc a1(&allocated1);
1697
+ MyAlloc a2(&allocated2);
1698
+ AllocVec v1(ia1, ia1 + ABSL_ARRAYSIZE(ia1), a1);
1699
+ AllocVec v2(ia2, ia2 + ABSL_ARRAYSIZE(ia2), a2);
1700
+ EXPECT_THAT(allocated1,
1701
+ Eq(static_cast<int64_t>(v1.capacity() * sizeof(int))));
1702
+ EXPECT_THAT(allocated2, Eq(0));
1703
+ v1.swap(v2);
1704
+ EXPECT_THAT(v1, ElementsAreArray(ia2));
1705
+ EXPECT_THAT(v2, ElementsAreArray(ia1));
1706
+ EXPECT_THAT(allocated1,
1707
+ Eq(static_cast<int64_t>(v2.capacity() * sizeof(int))));
1708
+ EXPECT_THAT(allocated2, Eq(0));
1709
+ EXPECT_TRUE(v2.get_allocator() == a1);
1710
+ EXPECT_TRUE(v1.get_allocator() == a2);
1711
+ }
1712
+ EXPECT_THAT(allocated1, 0);
1713
+ EXPECT_THAT(allocated2, 0);
1714
+ }
1715
+
1716
+ TEST(AllocatorSupportTest, ScopedAllocatorWorksInlined) {
1717
+ using StdVector = std::vector<int, CountingAllocator<int>>;
1718
+ using Alloc = CountingAllocator<StdVector>;
1719
+ using ScopedAlloc = std::scoped_allocator_adaptor<Alloc>;
1720
+ using AllocVec = absl::InlinedVector<StdVector, 1, ScopedAlloc>;
1721
+
1722
+ int64_t total_allocated_byte_count = 0;
1723
+
1724
+ AllocVec inlined_case(ScopedAlloc(Alloc(+&total_allocated_byte_count)));
1725
+
1726
+ // Called only once to remain inlined
1727
+ inlined_case.emplace_back();
1728
+
1729
+ int64_t absl_responsible_for_count = total_allocated_byte_count;
1730
+
1731
+ // MSVC's allocator preemptively allocates in debug mode
1732
+ #if !defined(_MSC_VER)
1733
+ EXPECT_EQ(absl_responsible_for_count, 0);
1734
+ #endif // !defined(_MSC_VER)
1735
+
1736
+ inlined_case[0].emplace_back();
1737
+ EXPECT_GT(total_allocated_byte_count, absl_responsible_for_count);
1738
+
1739
+ inlined_case.clear();
1740
+ inlined_case.shrink_to_fit();
1741
+ EXPECT_EQ(total_allocated_byte_count, 0);
1742
+ }
1743
+
1744
+ TEST(AllocatorSupportTest, ScopedAllocatorWorksAllocated) {
1745
+ using StdVector = std::vector<int, CountingAllocator<int>>;
1746
+ using Alloc = CountingAllocator<StdVector>;
1747
+ using ScopedAlloc = std::scoped_allocator_adaptor<Alloc>;
1748
+ using AllocVec = absl::InlinedVector<StdVector, 1, ScopedAlloc>;
1749
+
1750
+ int64_t total_allocated_byte_count = 0;
1751
+
1752
+ AllocVec allocated_case(ScopedAlloc(Alloc(+&total_allocated_byte_count)));
1753
+
1754
+ // Called twice to force into being allocated
1755
+ allocated_case.emplace_back();
1756
+ allocated_case.emplace_back();
1757
+
1758
+ int64_t absl_responsible_for_count = total_allocated_byte_count;
1759
+ EXPECT_GT(absl_responsible_for_count, 0);
1760
+
1761
+ allocated_case[1].emplace_back();
1762
+ EXPECT_GT(total_allocated_byte_count, absl_responsible_for_count);
1763
+
1764
+ allocated_case.clear();
1765
+ allocated_case.shrink_to_fit();
1766
+ EXPECT_EQ(total_allocated_byte_count, 0);
1767
+ }
1768
+
1769
+ TEST(AllocatorSupportTest, SizeAllocConstructor) {
1770
+ constexpr size_t inlined_size = 4;
1771
+ using Alloc = CountingAllocator<int>;
1772
+ using AllocVec = absl::InlinedVector<int, inlined_size, Alloc>;
1773
+
1774
+ {
1775
+ auto len = inlined_size / 2;
1776
+ int64_t allocated = 0;
1777
+ auto v = AllocVec(len, Alloc(&allocated));
1778
+
1779
+ // Inline storage used; allocator should not be invoked
1780
+ EXPECT_THAT(allocated, Eq(0));
1781
+ EXPECT_THAT(v, AllOf(SizeIs(len), Each(0)));
1782
+ }
1783
+
1784
+ {
1785
+ auto len = inlined_size * 2;
1786
+ int64_t allocated = 0;
1787
+ auto v = AllocVec(len, Alloc(&allocated));
1788
+
1789
+ // Out of line storage used; allocation of 8 elements expected
1790
+ EXPECT_THAT(allocated, Eq(static_cast<int64_t>(len * sizeof(int))));
1791
+ EXPECT_THAT(v, AllOf(SizeIs(len), Each(0)));
1792
+ }
1793
+ }
1794
+
1795
+ TEST(InlinedVectorTest, MinimumAllocatorCompilesUsingTraits) {
1796
+ using T = int;
1797
+ using A = std::allocator<T>;
1798
+ using ATraits = absl::allocator_traits<A>;
1799
+
1800
+ struct MinimumAllocator {
1801
+ using value_type = T;
1802
+
1803
+ value_type* allocate(size_t n) {
1804
+ A a;
1805
+ return ATraits::allocate(a, n);
1806
+ }
1807
+
1808
+ void deallocate(value_type* p, size_t n) {
1809
+ A a;
1810
+ ATraits::deallocate(a, p, n);
1811
+ }
1812
+ };
1813
+
1814
+ absl::InlinedVector<T, 1, MinimumAllocator> vec;
1815
+ vec.emplace_back();
1816
+ vec.resize(0);
1817
+ }
1818
+
1819
+ TEST(InlinedVectorTest, AbslHashValueWorks) {
1820
+ using V = absl::InlinedVector<int, 4>;
1821
+ std::vector<V> cases;
1822
+
1823
+ // Generate a variety of vectors some of these are small enough for the inline
1824
+ // space but are stored out of line.
1825
+ for (size_t i = 0; i < 10; ++i) {
1826
+ V v;
1827
+ for (int j = 0; j < static_cast<int>(i); ++j) {
1828
+ v.push_back(j);
1829
+ }
1830
+ cases.push_back(v);
1831
+ v.resize(i % 4);
1832
+ cases.push_back(v);
1833
+ }
1834
+
1835
+ EXPECT_TRUE(absl::VerifyTypeImplementsAbslHashCorrectly(cases));
1836
+ }
1837
+
1838
+ class MoveConstructibleOnlyInstance
1839
+ : public absl::test_internal::BaseCountedInstance {
1840
+ public:
1841
+ explicit MoveConstructibleOnlyInstance(int x) : BaseCountedInstance(x) {}
1842
+ MoveConstructibleOnlyInstance(MoveConstructibleOnlyInstance&& other) =
1843
+ default;
1844
+ MoveConstructibleOnlyInstance& operator=(
1845
+ MoveConstructibleOnlyInstance&& other) = delete;
1846
+ };
1847
+
1848
+ MATCHER(HasValue, "") {
1849
+ return ::testing::get<0>(arg).value() == ::testing::get<1>(arg);
1850
+ }
1851
+
1852
+ TEST(NonAssignableMoveAssignmentTest, AllocatedToInline) {
1853
+ using X = MoveConstructibleOnlyInstance;
1854
+ InstanceTracker tracker;
1855
+ absl::InlinedVector<X, 2> inlined;
1856
+ inlined.emplace_back(1);
1857
+ absl::InlinedVector<X, 2> allocated;
1858
+ allocated.emplace_back(1);
1859
+ allocated.emplace_back(2);
1860
+ allocated.emplace_back(3);
1861
+ tracker.ResetCopiesMovesSwaps();
1862
+
1863
+ inlined = std::move(allocated);
1864
+ // passed ownership of the allocated storage
1865
+ EXPECT_EQ(tracker.moves(), 0);
1866
+ EXPECT_EQ(tracker.live_instances(), 3);
1867
+
1868
+ EXPECT_THAT(inlined, Pointwise(HasValue(), {1, 2, 3}));
1869
+ }
1870
+
1871
+ TEST(NonAssignableMoveAssignmentTest, InlineToAllocated) {
1872
+ using X = MoveConstructibleOnlyInstance;
1873
+ InstanceTracker tracker;
1874
+ absl::InlinedVector<X, 2> inlined;
1875
+ inlined.emplace_back(1);
1876
+ absl::InlinedVector<X, 2> allocated;
1877
+ allocated.emplace_back(1);
1878
+ allocated.emplace_back(2);
1879
+ allocated.emplace_back(3);
1880
+ tracker.ResetCopiesMovesSwaps();
1881
+
1882
+ allocated = std::move(inlined);
1883
+ // Moved elements
1884
+ EXPECT_EQ(tracker.moves(), 1);
1885
+ EXPECT_EQ(tracker.live_instances(), 1);
1886
+
1887
+ EXPECT_THAT(allocated, Pointwise(HasValue(), {1}));
1888
+ }
1889
+
1890
+ TEST(NonAssignableMoveAssignmentTest, InlineToInline) {
1891
+ using X = MoveConstructibleOnlyInstance;
1892
+ InstanceTracker tracker;
1893
+ absl::InlinedVector<X, 2> inlined_a;
1894
+ inlined_a.emplace_back(1);
1895
+ absl::InlinedVector<X, 2> inlined_b;
1896
+ inlined_b.emplace_back(1);
1897
+ tracker.ResetCopiesMovesSwaps();
1898
+
1899
+ inlined_a = std::move(inlined_b);
1900
+ // Moved elements
1901
+ EXPECT_EQ(tracker.moves(), 1);
1902
+ EXPECT_EQ(tracker.live_instances(), 1);
1903
+
1904
+ EXPECT_THAT(inlined_a, Pointwise(HasValue(), {1}));
1905
+ }
1906
+
1907
+ TEST(NonAssignableMoveAssignmentTest, AllocatedToAllocated) {
1908
+ using X = MoveConstructibleOnlyInstance;
1909
+ InstanceTracker tracker;
1910
+ absl::InlinedVector<X, 2> allocated_a;
1911
+ allocated_a.emplace_back(1);
1912
+ allocated_a.emplace_back(2);
1913
+ allocated_a.emplace_back(3);
1914
+ absl::InlinedVector<X, 2> allocated_b;
1915
+ allocated_b.emplace_back(4);
1916
+ allocated_b.emplace_back(5);
1917
+ allocated_b.emplace_back(6);
1918
+ allocated_b.emplace_back(7);
1919
+ tracker.ResetCopiesMovesSwaps();
1920
+
1921
+ allocated_a = std::move(allocated_b);
1922
+ // passed ownership of the allocated storage
1923
+ EXPECT_EQ(tracker.moves(), 0);
1924
+ EXPECT_EQ(tracker.live_instances(), 4);
1925
+
1926
+ EXPECT_THAT(allocated_a, Pointwise(HasValue(), {4, 5, 6, 7}));
1927
+ }
1928
+
1929
+ TEST(NonAssignableMoveAssignmentTest, AssignThis) {
1930
+ using X = MoveConstructibleOnlyInstance;
1931
+ InstanceTracker tracker;
1932
+ absl::InlinedVector<X, 2> v;
1933
+ v.emplace_back(1);
1934
+ v.emplace_back(2);
1935
+ v.emplace_back(3);
1936
+
1937
+ tracker.ResetCopiesMovesSwaps();
1938
+
1939
+ // Obfuscated in order to pass -Wself-move.
1940
+ v = std::move(*std::addressof(v));
1941
+ // nothing happens
1942
+ EXPECT_EQ(tracker.moves(), 0);
1943
+ EXPECT_EQ(tracker.live_instances(), 3);
1944
+
1945
+ EXPECT_THAT(v, Pointwise(HasValue(), {1, 2, 3}));
1946
+ }
1947
+
1948
+ class NonSwappableInstance : public absl::test_internal::BaseCountedInstance {
1949
+ public:
1950
+ explicit NonSwappableInstance(int x) : BaseCountedInstance(x) {}
1951
+ NonSwappableInstance(const NonSwappableInstance& other) = default;
1952
+ NonSwappableInstance& operator=(const NonSwappableInstance& other) = default;
1953
+ NonSwappableInstance(NonSwappableInstance&& other) = default;
1954
+ NonSwappableInstance& operator=(NonSwappableInstance&& other) = default;
1955
+ };
1956
+
1957
+ void swap(NonSwappableInstance&, NonSwappableInstance&) = delete;
1958
+
1959
+ TEST(NonSwappableSwapTest, InlineAndAllocatedTransferStorageAndMove) {
1960
+ using X = NonSwappableInstance;
1961
+ InstanceTracker tracker;
1962
+ absl::InlinedVector<X, 2> inlined;
1963
+ inlined.emplace_back(1);
1964
+ absl::InlinedVector<X, 2> allocated;
1965
+ allocated.emplace_back(1);
1966
+ allocated.emplace_back(2);
1967
+ allocated.emplace_back(3);
1968
+ tracker.ResetCopiesMovesSwaps();
1969
+
1970
+ inlined.swap(allocated);
1971
+ EXPECT_EQ(tracker.moves(), 1);
1972
+ EXPECT_EQ(tracker.live_instances(), 4);
1973
+
1974
+ EXPECT_THAT(inlined, Pointwise(HasValue(), {1, 2, 3}));
1975
+ }
1976
+
1977
+ TEST(NonSwappableSwapTest, InlineAndInlineMoveIndividualElements) {
1978
+ using X = NonSwappableInstance;
1979
+ InstanceTracker tracker;
1980
+ absl::InlinedVector<X, 2> inlined_a;
1981
+ inlined_a.emplace_back(1);
1982
+ absl::InlinedVector<X, 2> inlined_b;
1983
+ inlined_b.emplace_back(2);
1984
+ tracker.ResetCopiesMovesSwaps();
1985
+
1986
+ inlined_a.swap(inlined_b);
1987
+ EXPECT_EQ(tracker.moves(), 3);
1988
+ EXPECT_EQ(tracker.live_instances(), 2);
1989
+
1990
+ EXPECT_THAT(inlined_a, Pointwise(HasValue(), {2}));
1991
+ EXPECT_THAT(inlined_b, Pointwise(HasValue(), {1}));
1992
+ }
1993
+
1994
+ TEST(NonSwappableSwapTest, AllocatedAndAllocatedOnlyTransferStorage) {
1995
+ using X = NonSwappableInstance;
1996
+ InstanceTracker tracker;
1997
+ absl::InlinedVector<X, 2> allocated_a;
1998
+ allocated_a.emplace_back(1);
1999
+ allocated_a.emplace_back(2);
2000
+ allocated_a.emplace_back(3);
2001
+ absl::InlinedVector<X, 2> allocated_b;
2002
+ allocated_b.emplace_back(4);
2003
+ allocated_b.emplace_back(5);
2004
+ allocated_b.emplace_back(6);
2005
+ allocated_b.emplace_back(7);
2006
+ tracker.ResetCopiesMovesSwaps();
2007
+
2008
+ allocated_a.swap(allocated_b);
2009
+ EXPECT_EQ(tracker.moves(), 0);
2010
+ EXPECT_EQ(tracker.live_instances(), 7);
2011
+
2012
+ EXPECT_THAT(allocated_a, Pointwise(HasValue(), {4, 5, 6, 7}));
2013
+ EXPECT_THAT(allocated_b, Pointwise(HasValue(), {1, 2, 3}));
2014
+ }
2015
+
2016
+ TEST(NonSwappableSwapTest, SwapThis) {
2017
+ using X = NonSwappableInstance;
2018
+ InstanceTracker tracker;
2019
+ absl::InlinedVector<X, 2> v;
2020
+ v.emplace_back(1);
2021
+ v.emplace_back(2);
2022
+ v.emplace_back(3);
2023
+
2024
+ tracker.ResetCopiesMovesSwaps();
2025
+
2026
+ v.swap(v);
2027
+ EXPECT_EQ(tracker.moves(), 0);
2028
+ EXPECT_EQ(tracker.live_instances(), 3);
2029
+
2030
+ EXPECT_THAT(v, Pointwise(HasValue(), {1, 2, 3}));
2031
+ }
2032
+
2033
+ template <size_t N>
2034
+ using CharVec = absl::InlinedVector<char, N>;
2035
+
2036
+ // Warning: This struct "simulates" the type `InlinedVector::Storage::Allocated`
2037
+ // to make reasonable expectations for inlined storage capacity optimization. If
2038
+ // implementation changes `Allocated`, then `MySpan` and tests that use it need
2039
+ // to be updated accordingly.
2040
+ template <typename T>
2041
+ struct MySpan {
2042
+ T* data;
2043
+ size_t size;
2044
+ };
2045
+
2046
+ TEST(StorageTest, InlinedCapacityAutoIncrease) {
2047
+ // The requested capacity is auto increased to `sizeof(MySpan<char>)`.
2048
+ EXPECT_GT(CharVec<1>().capacity(), 1);
2049
+ EXPECT_EQ(CharVec<1>().capacity(), sizeof(MySpan<char>));
2050
+ EXPECT_EQ(CharVec<1>().capacity(), CharVec<2>().capacity());
2051
+ EXPECT_EQ(sizeof(CharVec<1>), sizeof(CharVec<2>));
2052
+
2053
+ // The requested capacity is auto increased to
2054
+ // `sizeof(MySpan<int>) / sizeof(int)`.
2055
+ EXPECT_GT((absl::InlinedVector<int, 1>().capacity()), 1);
2056
+ EXPECT_EQ((absl::InlinedVector<int, 1>().capacity()),
2057
+ sizeof(MySpan<int>) / sizeof(int));
2058
+ }
2059
+
2060
+ } // anonymous namespace