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,1847 @@
1
+ // Copyright 2020 The Abseil Authors.
2
+ //
3
+ // Licensed under the Apache License, Version 2.0 (the "License");
4
+ // you may not use this file except in compliance with the License.
5
+ // You may obtain a copy of the License at
6
+ //
7
+ // https://www.apache.org/licenses/LICENSE-2.0
8
+ //
9
+ // Unless required by applicable law or agreed to in writing, software
10
+ // distributed under the License is distributed on an "AS IS" BASIS,
11
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ // See the License for the specific language governing permissions and
13
+ // limitations under the License.
14
+
15
+ #include "absl/status/statusor.h"
16
+
17
+ #include <array>
18
+ #include <initializer_list>
19
+ #include <memory>
20
+ #include <string>
21
+ #include <type_traits>
22
+ #include <utility>
23
+
24
+ #include "gmock/gmock.h"
25
+ #include "gtest/gtest.h"
26
+ #include "absl/base/casts.h"
27
+ #include "absl/memory/memory.h"
28
+ #include "absl/status/status.h"
29
+ #include "absl/strings/string_view.h"
30
+ #include "absl/types/any.h"
31
+ #include "absl/utility/utility.h"
32
+
33
+ namespace {
34
+
35
+ using ::testing::AllOf;
36
+ using ::testing::AnyWith;
37
+ using ::testing::ElementsAre;
38
+ using ::testing::Field;
39
+ using ::testing::HasSubstr;
40
+ using ::testing::Ne;
41
+ using ::testing::Not;
42
+ using ::testing::Pointee;
43
+ using ::testing::VariantWith;
44
+
45
+ #ifdef GTEST_HAS_STATUS_MATCHERS
46
+ using ::testing::status::IsOk;
47
+ using ::testing::status::IsOkAndHolds;
48
+ #else // GTEST_HAS_STATUS_MATCHERS
49
+ inline const ::absl::Status& GetStatus(const ::absl::Status& status) {
50
+ return status;
51
+ }
52
+
53
+ template <typename T>
54
+ inline const ::absl::Status& GetStatus(const ::absl::StatusOr<T>& status) {
55
+ return status.status();
56
+ }
57
+
58
+ // Monomorphic implementation of matcher IsOkAndHolds(m). StatusOrType is a
59
+ // reference to StatusOr<T>.
60
+ template <typename StatusOrType>
61
+ class IsOkAndHoldsMatcherImpl
62
+ : public ::testing::MatcherInterface<StatusOrType> {
63
+ public:
64
+ typedef
65
+ typename std::remove_reference<StatusOrType>::type::value_type value_type;
66
+
67
+ template <typename InnerMatcher>
68
+ explicit IsOkAndHoldsMatcherImpl(InnerMatcher&& inner_matcher)
69
+ : inner_matcher_(::testing::SafeMatcherCast<const value_type&>(
70
+ std::forward<InnerMatcher>(inner_matcher))) {}
71
+
72
+ void DescribeTo(std::ostream* os) const override {
73
+ *os << "is OK and has a value that ";
74
+ inner_matcher_.DescribeTo(os);
75
+ }
76
+
77
+ void DescribeNegationTo(std::ostream* os) const override {
78
+ *os << "isn't OK or has a value that ";
79
+ inner_matcher_.DescribeNegationTo(os);
80
+ }
81
+
82
+ bool MatchAndExplain(
83
+ StatusOrType actual_value,
84
+ ::testing::MatchResultListener* result_listener) const override {
85
+ if (!actual_value.ok()) {
86
+ *result_listener << "which has status " << actual_value.status();
87
+ return false;
88
+ }
89
+
90
+ ::testing::StringMatchResultListener inner_listener;
91
+ const bool matches =
92
+ inner_matcher_.MatchAndExplain(*actual_value, &inner_listener);
93
+ const std::string inner_explanation = inner_listener.str();
94
+ if (!inner_explanation.empty()) {
95
+ *result_listener << "which contains value "
96
+ << ::testing::PrintToString(*actual_value) << ", "
97
+ << inner_explanation;
98
+ }
99
+ return matches;
100
+ }
101
+
102
+ private:
103
+ const ::testing::Matcher<const value_type&> inner_matcher_;
104
+ };
105
+
106
+ // Implements IsOkAndHolds(m) as a polymorphic matcher.
107
+ template <typename InnerMatcher>
108
+ class IsOkAndHoldsMatcher {
109
+ public:
110
+ explicit IsOkAndHoldsMatcher(InnerMatcher inner_matcher)
111
+ : inner_matcher_(std::move(inner_matcher)) {}
112
+
113
+ // Converts this polymorphic matcher to a monomorphic matcher of the
114
+ // given type. StatusOrType can be either StatusOr<T> or a
115
+ // reference to StatusOr<T>.
116
+ template <typename StatusOrType>
117
+ operator ::testing::Matcher<StatusOrType>() const { // NOLINT
118
+ return ::testing::Matcher<StatusOrType>(
119
+ new IsOkAndHoldsMatcherImpl<const StatusOrType&>(inner_matcher_));
120
+ }
121
+
122
+ private:
123
+ const InnerMatcher inner_matcher_;
124
+ };
125
+
126
+ // Monomorphic implementation of matcher IsOk() for a given type T.
127
+ // T can be Status, StatusOr<>, or a reference to either of them.
128
+ template <typename T>
129
+ class MonoIsOkMatcherImpl : public ::testing::MatcherInterface<T> {
130
+ public:
131
+ void DescribeTo(std::ostream* os) const override { *os << "is OK"; }
132
+ void DescribeNegationTo(std::ostream* os) const override {
133
+ *os << "is not OK";
134
+ }
135
+ bool MatchAndExplain(T actual_value,
136
+ ::testing::MatchResultListener*) const override {
137
+ return GetStatus(actual_value).ok();
138
+ }
139
+ };
140
+
141
+ // Implements IsOk() as a polymorphic matcher.
142
+ class IsOkMatcher {
143
+ public:
144
+ template <typename T>
145
+ operator ::testing::Matcher<T>() const { // NOLINT
146
+ return ::testing::Matcher<T>(new MonoIsOkMatcherImpl<T>());
147
+ }
148
+ };
149
+
150
+ // Macros for testing the results of functions that return absl::Status or
151
+ // absl::StatusOr<T> (for any type T).
152
+ #define EXPECT_OK(expression) EXPECT_THAT(expression, IsOk())
153
+
154
+ // Returns a gMock matcher that matches a StatusOr<> whose status is
155
+ // OK and whose value matches the inner matcher.
156
+ template <typename InnerMatcher>
157
+ IsOkAndHoldsMatcher<typename std::decay<InnerMatcher>::type> IsOkAndHolds(
158
+ InnerMatcher&& inner_matcher) {
159
+ return IsOkAndHoldsMatcher<typename std::decay<InnerMatcher>::type>(
160
+ std::forward<InnerMatcher>(inner_matcher));
161
+ }
162
+
163
+ // Returns a gMock matcher that matches a Status or StatusOr<> which is OK.
164
+ inline IsOkMatcher IsOk() { return IsOkMatcher(); }
165
+ #endif // GTEST_HAS_STATUS_MATCHERS
166
+
167
+ struct CopyDetector {
168
+ CopyDetector() = default;
169
+ explicit CopyDetector(int xx) : x(xx) {}
170
+ CopyDetector(CopyDetector&& d) noexcept
171
+ : x(d.x), copied(false), moved(true) {}
172
+ CopyDetector(const CopyDetector& d) : x(d.x), copied(true), moved(false) {}
173
+ CopyDetector& operator=(const CopyDetector& c) {
174
+ x = c.x;
175
+ copied = true;
176
+ moved = false;
177
+ return *this;
178
+ }
179
+ CopyDetector& operator=(CopyDetector&& c) noexcept {
180
+ x = c.x;
181
+ copied = false;
182
+ moved = true;
183
+ return *this;
184
+ }
185
+ int x = 0;
186
+ bool copied = false;
187
+ bool moved = false;
188
+ };
189
+
190
+ testing::Matcher<const CopyDetector&> CopyDetectorHas(int a, bool b, bool c) {
191
+ return AllOf(Field(&CopyDetector::x, a), Field(&CopyDetector::moved, b),
192
+ Field(&CopyDetector::copied, c));
193
+ }
194
+
195
+ class Base1 {
196
+ public:
197
+ virtual ~Base1() {}
198
+ int pad;
199
+ };
200
+
201
+ class Base2 {
202
+ public:
203
+ virtual ~Base2() {}
204
+ int yetotherpad;
205
+ };
206
+
207
+ class Derived : public Base1, public Base2 {
208
+ public:
209
+ virtual ~Derived() {}
210
+ int evenmorepad;
211
+ };
212
+
213
+ class CopyNoAssign {
214
+ public:
215
+ explicit CopyNoAssign(int value) : foo(value) {}
216
+ CopyNoAssign(const CopyNoAssign& other) : foo(other.foo) {}
217
+ int foo;
218
+
219
+ private:
220
+ const CopyNoAssign& operator=(const CopyNoAssign&);
221
+ };
222
+
223
+ absl::StatusOr<std::unique_ptr<int>> ReturnUniquePtr() {
224
+ // Uses implicit constructor from T&&
225
+ return absl::make_unique<int>(0);
226
+ }
227
+
228
+ TEST(StatusOr, ElementType) {
229
+ static_assert(std::is_same<absl::StatusOr<int>::value_type, int>(), "");
230
+ static_assert(std::is_same<absl::StatusOr<char>::value_type, char>(), "");
231
+ }
232
+
233
+ TEST(StatusOr, TestMoveOnlyInitialization) {
234
+ absl::StatusOr<std::unique_ptr<int>> thing(ReturnUniquePtr());
235
+ ASSERT_TRUE(thing.ok());
236
+ EXPECT_EQ(0, **thing);
237
+ int* previous = thing->get();
238
+
239
+ thing = ReturnUniquePtr();
240
+ EXPECT_TRUE(thing.ok());
241
+ EXPECT_EQ(0, **thing);
242
+ EXPECT_NE(previous, thing->get());
243
+ }
244
+
245
+ TEST(StatusOr, TestMoveOnlyValueExtraction) {
246
+ absl::StatusOr<std::unique_ptr<int>> thing(ReturnUniquePtr());
247
+ ASSERT_TRUE(thing.ok());
248
+ std::unique_ptr<int> ptr = *std::move(thing);
249
+ EXPECT_EQ(0, *ptr);
250
+
251
+ thing = std::move(ptr);
252
+ ptr = std::move(*thing);
253
+ EXPECT_EQ(0, *ptr);
254
+ }
255
+
256
+ TEST(StatusOr, TestMoveOnlyInitializationFromTemporaryByValueOrDie) {
257
+ std::unique_ptr<int> ptr(*ReturnUniquePtr());
258
+ EXPECT_EQ(0, *ptr);
259
+ }
260
+
261
+ TEST(StatusOr, TestValueOrDieOverloadForConstTemporary) {
262
+ static_assert(
263
+ std::is_same<
264
+ const int&&,
265
+ decltype(std::declval<const absl::StatusOr<int>&&>().value())>(),
266
+ "value() for const temporaries should return const T&&");
267
+ }
268
+
269
+ TEST(StatusOr, TestMoveOnlyConversion) {
270
+ absl::StatusOr<std::unique_ptr<const int>> const_thing(ReturnUniquePtr());
271
+ EXPECT_TRUE(const_thing.ok());
272
+ EXPECT_EQ(0, **const_thing);
273
+
274
+ // Test rvalue converting assignment
275
+ const int* const_previous = const_thing->get();
276
+ const_thing = ReturnUniquePtr();
277
+ EXPECT_TRUE(const_thing.ok());
278
+ EXPECT_EQ(0, **const_thing);
279
+ EXPECT_NE(const_previous, const_thing->get());
280
+ }
281
+
282
+ TEST(StatusOr, TestMoveOnlyVector) {
283
+ // Sanity check that absl::StatusOr<MoveOnly> works in vector.
284
+ std::vector<absl::StatusOr<std::unique_ptr<int>>> vec;
285
+ vec.push_back(ReturnUniquePtr());
286
+ vec.resize(2);
287
+ auto another_vec = std::move(vec);
288
+ EXPECT_EQ(0, **another_vec[0]);
289
+ EXPECT_EQ(absl::UnknownError(""), another_vec[1].status());
290
+ }
291
+
292
+ TEST(StatusOr, TestDefaultCtor) {
293
+ absl::StatusOr<int> thing;
294
+ EXPECT_FALSE(thing.ok());
295
+ EXPECT_EQ(thing.status().code(), absl::StatusCode::kUnknown);
296
+ }
297
+
298
+ TEST(StatusOr, StatusCtorForwards) {
299
+ absl::Status status(absl::StatusCode::kInternal, "Some error");
300
+
301
+ EXPECT_EQ(absl::StatusOr<int>(status).status().message(), "Some error");
302
+ EXPECT_EQ(status.message(), "Some error");
303
+
304
+ EXPECT_EQ(absl::StatusOr<int>(std::move(status)).status().message(),
305
+ "Some error");
306
+ EXPECT_NE(status.message(), "Some error");
307
+ }
308
+
309
+ TEST(BadStatusOrAccessTest, CopyConstructionWhatOk) {
310
+ absl::Status error =
311
+ absl::InternalError("some arbitrary message too big for the sso buffer");
312
+ absl::BadStatusOrAccess e1{error};
313
+ absl::BadStatusOrAccess e2{e1};
314
+ EXPECT_THAT(e1.what(), HasSubstr(error.ToString()));
315
+ EXPECT_THAT(e2.what(), HasSubstr(error.ToString()));
316
+ }
317
+
318
+ TEST(BadStatusOrAccessTest, CopyAssignmentWhatOk) {
319
+ absl::Status error =
320
+ absl::InternalError("some arbitrary message too big for the sso buffer");
321
+ absl::BadStatusOrAccess e1{error};
322
+ absl::BadStatusOrAccess e2{absl::InternalError("other")};
323
+ e2 = e1;
324
+ EXPECT_THAT(e1.what(), HasSubstr(error.ToString()));
325
+ EXPECT_THAT(e2.what(), HasSubstr(error.ToString()));
326
+ }
327
+
328
+ TEST(BadStatusOrAccessTest, MoveConstructionWhatOk) {
329
+ absl::Status error =
330
+ absl::InternalError("some arbitrary message too big for the sso buffer");
331
+ absl::BadStatusOrAccess e1{error};
332
+ absl::BadStatusOrAccess e2{std::move(e1)};
333
+ EXPECT_THAT(e2.what(), HasSubstr(error.ToString()));
334
+ }
335
+
336
+ TEST(BadStatusOrAccessTest, MoveAssignmentWhatOk) {
337
+ absl::Status error =
338
+ absl::InternalError("some arbitrary message too big for the sso buffer");
339
+ absl::BadStatusOrAccess e1{error};
340
+ absl::BadStatusOrAccess e2{absl::InternalError("other")};
341
+ e2 = std::move(e1);
342
+ EXPECT_THAT(e2.what(), HasSubstr(error.ToString()));
343
+ }
344
+
345
+ // Define `EXPECT_DEATH_OR_THROW` to test the behavior of `StatusOr::value`,
346
+ // which either throws `BadStatusOrAccess` or `LOG(FATAL)` based on whether
347
+ // exceptions are enabled.
348
+ #ifdef ABSL_HAVE_EXCEPTIONS
349
+ #define EXPECT_DEATH_OR_THROW(statement, status_) \
350
+ EXPECT_THROW( \
351
+ { \
352
+ try { \
353
+ statement; \
354
+ } catch (const absl::BadStatusOrAccess& e) { \
355
+ EXPECT_EQ(e.status(), status_); \
356
+ EXPECT_THAT(e.what(), HasSubstr(e.status().ToString())); \
357
+ throw; \
358
+ } \
359
+ }, \
360
+ absl::BadStatusOrAccess);
361
+ #else // ABSL_HAVE_EXCEPTIONS
362
+ #define EXPECT_DEATH_OR_THROW(statement, status) \
363
+ EXPECT_DEATH_IF_SUPPORTED(statement, status.ToString());
364
+ #endif // ABSL_HAVE_EXCEPTIONS
365
+
366
+ TEST(StatusOrDeathTest, TestDefaultCtorValue) {
367
+ absl::StatusOr<int> thing;
368
+ EXPECT_DEATH_OR_THROW(thing.value(), absl::UnknownError(""));
369
+ const absl::StatusOr<int> thing2;
370
+ EXPECT_DEATH_OR_THROW(thing2.value(), absl::UnknownError(""));
371
+ }
372
+
373
+ TEST(StatusOrDeathTest, TestValueNotOk) {
374
+ absl::StatusOr<int> thing(absl::CancelledError());
375
+ EXPECT_DEATH_OR_THROW(thing.value(), absl::CancelledError());
376
+ }
377
+
378
+ TEST(StatusOrDeathTest, TestValueNotOkConst) {
379
+ const absl::StatusOr<int> thing(absl::UnknownError(""));
380
+ EXPECT_DEATH_OR_THROW(thing.value(), absl::UnknownError(""));
381
+ }
382
+
383
+ TEST(StatusOrDeathTest, TestPointerDefaultCtorValue) {
384
+ absl::StatusOr<int*> thing;
385
+ EXPECT_DEATH_OR_THROW(thing.value(), absl::UnknownError(""));
386
+ }
387
+
388
+ TEST(StatusOrDeathTest, TestPointerValueNotOk) {
389
+ absl::StatusOr<int*> thing(absl::CancelledError());
390
+ EXPECT_DEATH_OR_THROW(thing.value(), absl::CancelledError());
391
+ }
392
+
393
+ TEST(StatusOrDeathTest, TestPointerValueNotOkConst) {
394
+ const absl::StatusOr<int*> thing(absl::CancelledError());
395
+ EXPECT_DEATH_OR_THROW(thing.value(), absl::CancelledError());
396
+ }
397
+
398
+ #if GTEST_HAS_DEATH_TEST
399
+ TEST(StatusOrDeathTest, TestStatusCtorStatusOk) {
400
+ EXPECT_DEBUG_DEATH(
401
+ {
402
+ // This will DCHECK
403
+ absl::StatusOr<int> thing(absl::OkStatus());
404
+ // In optimized mode, we are actually going to get error::INTERNAL for
405
+ // status here, rather than crashing, so check that.
406
+ EXPECT_FALSE(thing.ok());
407
+ EXPECT_EQ(thing.status().code(), absl::StatusCode::kInternal);
408
+ },
409
+ "An OK status is not a valid constructor argument");
410
+ }
411
+
412
+ TEST(StatusOrDeathTest, TestPointerStatusCtorStatusOk) {
413
+ EXPECT_DEBUG_DEATH(
414
+ {
415
+ absl::StatusOr<int*> thing(absl::OkStatus());
416
+ // In optimized mode, we are actually going to get error::INTERNAL for
417
+ // status here, rather than crashing, so check that.
418
+ EXPECT_FALSE(thing.ok());
419
+ EXPECT_EQ(thing.status().code(), absl::StatusCode::kInternal);
420
+ },
421
+ "An OK status is not a valid constructor argument");
422
+ }
423
+ #endif
424
+
425
+ TEST(StatusOr, ValueAccessor) {
426
+ const int kIntValue = 110;
427
+ {
428
+ absl::StatusOr<int> status_or(kIntValue);
429
+ EXPECT_EQ(kIntValue, status_or.value());
430
+ EXPECT_EQ(kIntValue, std::move(status_or).value());
431
+ }
432
+ {
433
+ absl::StatusOr<CopyDetector> status_or(kIntValue);
434
+ EXPECT_THAT(status_or,
435
+ IsOkAndHolds(CopyDetectorHas(kIntValue, false, false)));
436
+ CopyDetector copy_detector = status_or.value();
437
+ EXPECT_THAT(copy_detector, CopyDetectorHas(kIntValue, false, true));
438
+ copy_detector = std::move(status_or).value();
439
+ EXPECT_THAT(copy_detector, CopyDetectorHas(kIntValue, true, false));
440
+ }
441
+ }
442
+
443
+ TEST(StatusOr, BadValueAccess) {
444
+ const absl::Status kError = absl::CancelledError("message");
445
+ absl::StatusOr<int> status_or(kError);
446
+ EXPECT_DEATH_OR_THROW(status_or.value(), kError);
447
+ }
448
+
449
+ TEST(StatusOr, TestStatusCtor) {
450
+ absl::StatusOr<int> thing(absl::CancelledError());
451
+ EXPECT_FALSE(thing.ok());
452
+ EXPECT_EQ(thing.status().code(), absl::StatusCode::kCancelled);
453
+ }
454
+
455
+ TEST(StatusOr, TestValueCtor) {
456
+ const int kI = 4;
457
+ const absl::StatusOr<int> thing(kI);
458
+ EXPECT_TRUE(thing.ok());
459
+ EXPECT_EQ(kI, *thing);
460
+ }
461
+
462
+ struct Foo {
463
+ const int x;
464
+ explicit Foo(int y) : x(y) {}
465
+ };
466
+
467
+ TEST(StatusOr, InPlaceConstruction) {
468
+ EXPECT_THAT(absl::StatusOr<Foo>(absl::in_place, 10),
469
+ IsOkAndHolds(Field(&Foo::x, 10)));
470
+ }
471
+
472
+ struct InPlaceHelper {
473
+ InPlaceHelper(std::initializer_list<int> xs, std::unique_ptr<int> yy)
474
+ : x(xs), y(std::move(yy)) {}
475
+ const std::vector<int> x;
476
+ std::unique_ptr<int> y;
477
+ };
478
+
479
+ TEST(StatusOr, InPlaceInitListConstruction) {
480
+ absl::StatusOr<InPlaceHelper> status_or(absl::in_place, {10, 11, 12},
481
+ absl::make_unique<int>(13));
482
+ EXPECT_THAT(status_or, IsOkAndHolds(AllOf(
483
+ Field(&InPlaceHelper::x, ElementsAre(10, 11, 12)),
484
+ Field(&InPlaceHelper::y, Pointee(13)))));
485
+ }
486
+
487
+ TEST(StatusOr, Emplace) {
488
+ absl::StatusOr<Foo> status_or_foo(10);
489
+ status_or_foo.emplace(20);
490
+ EXPECT_THAT(status_or_foo, IsOkAndHolds(Field(&Foo::x, 20)));
491
+ status_or_foo = absl::InvalidArgumentError("msg");
492
+ EXPECT_FALSE(status_or_foo.ok());
493
+ EXPECT_EQ(status_or_foo.status().code(), absl::StatusCode::kInvalidArgument);
494
+ EXPECT_EQ(status_or_foo.status().message(), "msg");
495
+ status_or_foo.emplace(20);
496
+ EXPECT_THAT(status_or_foo, IsOkAndHolds(Field(&Foo::x, 20)));
497
+ }
498
+
499
+ TEST(StatusOr, EmplaceInitializerList) {
500
+ absl::StatusOr<InPlaceHelper> status_or(absl::in_place, {10, 11, 12},
501
+ absl::make_unique<int>(13));
502
+ status_or.emplace({1, 2, 3}, absl::make_unique<int>(4));
503
+ EXPECT_THAT(status_or,
504
+ IsOkAndHolds(AllOf(Field(&InPlaceHelper::x, ElementsAre(1, 2, 3)),
505
+ Field(&InPlaceHelper::y, Pointee(4)))));
506
+ status_or = absl::InvalidArgumentError("msg");
507
+ EXPECT_FALSE(status_or.ok());
508
+ EXPECT_EQ(status_or.status().code(), absl::StatusCode::kInvalidArgument);
509
+ EXPECT_EQ(status_or.status().message(), "msg");
510
+ status_or.emplace({1, 2, 3}, absl::make_unique<int>(4));
511
+ EXPECT_THAT(status_or,
512
+ IsOkAndHolds(AllOf(Field(&InPlaceHelper::x, ElementsAre(1, 2, 3)),
513
+ Field(&InPlaceHelper::y, Pointee(4)))));
514
+ }
515
+
516
+ TEST(StatusOr, TestCopyCtorStatusOk) {
517
+ const int kI = 4;
518
+ const absl::StatusOr<int> original(kI);
519
+ const absl::StatusOr<int> copy(original);
520
+ EXPECT_OK(copy.status());
521
+ EXPECT_EQ(*original, *copy);
522
+ }
523
+
524
+ TEST(StatusOr, TestCopyCtorStatusNotOk) {
525
+ absl::StatusOr<int> original(absl::CancelledError());
526
+ absl::StatusOr<int> copy(original);
527
+ EXPECT_EQ(copy.status().code(), absl::StatusCode::kCancelled);
528
+ }
529
+
530
+ TEST(StatusOr, TestCopyCtorNonAssignable) {
531
+ const int kI = 4;
532
+ CopyNoAssign value(kI);
533
+ absl::StatusOr<CopyNoAssign> original(value);
534
+ absl::StatusOr<CopyNoAssign> copy(original);
535
+ EXPECT_OK(copy.status());
536
+ EXPECT_EQ(original->foo, copy->foo);
537
+ }
538
+
539
+ TEST(StatusOr, TestCopyCtorStatusOKConverting) {
540
+ const int kI = 4;
541
+ absl::StatusOr<int> original(kI);
542
+ absl::StatusOr<double> copy(original);
543
+ EXPECT_OK(copy.status());
544
+ EXPECT_DOUBLE_EQ(*original, *copy);
545
+ }
546
+
547
+ TEST(StatusOr, TestCopyCtorStatusNotOkConverting) {
548
+ absl::StatusOr<int> original(absl::CancelledError());
549
+ absl::StatusOr<double> copy(original);
550
+ EXPECT_EQ(copy.status(), original.status());
551
+ }
552
+
553
+ TEST(StatusOr, TestAssignmentStatusOk) {
554
+ // Copy assignmment
555
+ {
556
+ const auto p = std::make_shared<int>(17);
557
+ absl::StatusOr<std::shared_ptr<int>> source(p);
558
+
559
+ absl::StatusOr<std::shared_ptr<int>> target;
560
+ target = source;
561
+
562
+ ASSERT_TRUE(target.ok());
563
+ EXPECT_OK(target.status());
564
+ EXPECT_EQ(p, *target);
565
+
566
+ ASSERT_TRUE(source.ok());
567
+ EXPECT_OK(source.status());
568
+ EXPECT_EQ(p, *source);
569
+ }
570
+
571
+ // Move asssignment
572
+ {
573
+ const auto p = std::make_shared<int>(17);
574
+ absl::StatusOr<std::shared_ptr<int>> source(p);
575
+
576
+ absl::StatusOr<std::shared_ptr<int>> target;
577
+ target = std::move(source);
578
+
579
+ ASSERT_TRUE(target.ok());
580
+ EXPECT_OK(target.status());
581
+ EXPECT_EQ(p, *target);
582
+
583
+ ASSERT_TRUE(source.ok());
584
+ EXPECT_OK(source.status());
585
+ EXPECT_EQ(nullptr, *source);
586
+ }
587
+ }
588
+
589
+ TEST(StatusOr, TestAssignmentStatusNotOk) {
590
+ // Copy assignment
591
+ {
592
+ const absl::Status expected = absl::CancelledError();
593
+ absl::StatusOr<int> source(expected);
594
+
595
+ absl::StatusOr<int> target;
596
+ target = source;
597
+
598
+ EXPECT_FALSE(target.ok());
599
+ EXPECT_EQ(expected, target.status());
600
+
601
+ EXPECT_FALSE(source.ok());
602
+ EXPECT_EQ(expected, source.status());
603
+ }
604
+
605
+ // Move assignment
606
+ {
607
+ const absl::Status expected = absl::CancelledError();
608
+ absl::StatusOr<int> source(expected);
609
+
610
+ absl::StatusOr<int> target;
611
+ target = std::move(source);
612
+
613
+ EXPECT_FALSE(target.ok());
614
+ EXPECT_EQ(expected, target.status());
615
+
616
+ EXPECT_FALSE(source.ok());
617
+ EXPECT_EQ(source.status().code(), absl::StatusCode::kInternal);
618
+ }
619
+ }
620
+
621
+ TEST(StatusOr, TestAssignmentStatusOKConverting) {
622
+ // Copy assignment
623
+ {
624
+ const int kI = 4;
625
+ absl::StatusOr<int> source(kI);
626
+
627
+ absl::StatusOr<double> target;
628
+ target = source;
629
+
630
+ ASSERT_TRUE(target.ok());
631
+ EXPECT_OK(target.status());
632
+ EXPECT_DOUBLE_EQ(kI, *target);
633
+
634
+ ASSERT_TRUE(source.ok());
635
+ EXPECT_OK(source.status());
636
+ EXPECT_DOUBLE_EQ(kI, *source);
637
+ }
638
+
639
+ // Move assignment
640
+ {
641
+ const auto p = new int(17);
642
+ absl::StatusOr<std::unique_ptr<int>> source(absl::WrapUnique(p));
643
+
644
+ absl::StatusOr<std::shared_ptr<int>> target;
645
+ target = std::move(source);
646
+
647
+ ASSERT_TRUE(target.ok());
648
+ EXPECT_OK(target.status());
649
+ EXPECT_EQ(p, target->get());
650
+
651
+ ASSERT_TRUE(source.ok());
652
+ EXPECT_OK(source.status());
653
+ EXPECT_EQ(nullptr, source->get());
654
+ }
655
+ }
656
+
657
+ struct A {
658
+ int x;
659
+ };
660
+
661
+ struct ImplicitConstructibleFromA {
662
+ int x;
663
+ bool moved;
664
+ ImplicitConstructibleFromA(const A& a) // NOLINT
665
+ : x(a.x), moved(false) {}
666
+ ImplicitConstructibleFromA(A&& a) // NOLINT
667
+ : x(a.x), moved(true) {}
668
+ };
669
+
670
+ TEST(StatusOr, ImplicitConvertingConstructor) {
671
+ EXPECT_THAT(
672
+ absl::implicit_cast<absl::StatusOr<ImplicitConstructibleFromA>>(
673
+ absl::StatusOr<A>(A{11})),
674
+ IsOkAndHolds(AllOf(Field(&ImplicitConstructibleFromA::x, 11),
675
+ Field(&ImplicitConstructibleFromA::moved, true))));
676
+ absl::StatusOr<A> a(A{12});
677
+ EXPECT_THAT(
678
+ absl::implicit_cast<absl::StatusOr<ImplicitConstructibleFromA>>(a),
679
+ IsOkAndHolds(AllOf(Field(&ImplicitConstructibleFromA::x, 12),
680
+ Field(&ImplicitConstructibleFromA::moved, false))));
681
+ }
682
+
683
+ struct ExplicitConstructibleFromA {
684
+ int x;
685
+ bool moved;
686
+ explicit ExplicitConstructibleFromA(const A& a) : x(a.x), moved(false) {}
687
+ explicit ExplicitConstructibleFromA(A&& a) : x(a.x), moved(true) {}
688
+ };
689
+
690
+ TEST(StatusOr, ExplicitConvertingConstructor) {
691
+ EXPECT_FALSE(
692
+ (std::is_convertible<const absl::StatusOr<A>&,
693
+ absl::StatusOr<ExplicitConstructibleFromA>>::value));
694
+ EXPECT_FALSE(
695
+ (std::is_convertible<absl::StatusOr<A>&&,
696
+ absl::StatusOr<ExplicitConstructibleFromA>>::value));
697
+ EXPECT_THAT(
698
+ absl::StatusOr<ExplicitConstructibleFromA>(absl::StatusOr<A>(A{11})),
699
+ IsOkAndHolds(AllOf(Field(&ExplicitConstructibleFromA::x, 11),
700
+ Field(&ExplicitConstructibleFromA::moved, true))));
701
+ absl::StatusOr<A> a(A{12});
702
+ EXPECT_THAT(
703
+ absl::StatusOr<ExplicitConstructibleFromA>(a),
704
+ IsOkAndHolds(AllOf(Field(&ExplicitConstructibleFromA::x, 12),
705
+ Field(&ExplicitConstructibleFromA::moved, false))));
706
+ }
707
+
708
+ struct ImplicitConstructibleFromBool {
709
+ ImplicitConstructibleFromBool(bool y) : x(y) {} // NOLINT
710
+ bool x = false;
711
+ };
712
+
713
+ struct ConvertibleToBool {
714
+ explicit ConvertibleToBool(bool y) : x(y) {}
715
+ operator bool() const { return x; } // NOLINT
716
+ bool x = false;
717
+ };
718
+
719
+ TEST(StatusOr, ImplicitBooleanConstructionWithImplicitCasts) {
720
+ EXPECT_THAT(absl::StatusOr<bool>(absl::StatusOr<ConvertibleToBool>(true)),
721
+ IsOkAndHolds(true));
722
+ EXPECT_THAT(absl::StatusOr<bool>(absl::StatusOr<ConvertibleToBool>(false)),
723
+ IsOkAndHolds(false));
724
+ EXPECT_THAT(
725
+ absl::implicit_cast<absl::StatusOr<ImplicitConstructibleFromBool>>(
726
+ absl::StatusOr<bool>(false)),
727
+ IsOkAndHolds(Field(&ImplicitConstructibleFromBool::x, false)));
728
+ EXPECT_FALSE((std::is_convertible<
729
+ absl::StatusOr<ConvertibleToBool>,
730
+ absl::StatusOr<ImplicitConstructibleFromBool>>::value));
731
+ }
732
+
733
+ TEST(StatusOr, BooleanConstructionWithImplicitCasts) {
734
+ EXPECT_THAT(absl::StatusOr<bool>(absl::StatusOr<ConvertibleToBool>(true)),
735
+ IsOkAndHolds(true));
736
+ EXPECT_THAT(absl::StatusOr<bool>(absl::StatusOr<ConvertibleToBool>(false)),
737
+ IsOkAndHolds(false));
738
+ EXPECT_THAT(
739
+ absl::StatusOr<ImplicitConstructibleFromBool>{
740
+ absl::StatusOr<bool>(false)},
741
+ IsOkAndHolds(Field(&ImplicitConstructibleFromBool::x, false)));
742
+ EXPECT_THAT(
743
+ absl::StatusOr<ImplicitConstructibleFromBool>{
744
+ absl::StatusOr<bool>(absl::InvalidArgumentError(""))},
745
+ Not(IsOk()));
746
+
747
+ EXPECT_THAT(
748
+ absl::StatusOr<ImplicitConstructibleFromBool>{
749
+ absl::StatusOr<ConvertibleToBool>(ConvertibleToBool{false})},
750
+ IsOkAndHolds(Field(&ImplicitConstructibleFromBool::x, false)));
751
+ EXPECT_THAT(
752
+ absl::StatusOr<ImplicitConstructibleFromBool>{
753
+ absl::StatusOr<ConvertibleToBool>(absl::InvalidArgumentError(""))},
754
+ Not(IsOk()));
755
+ }
756
+
757
+ TEST(StatusOr, ConstImplicitCast) {
758
+ EXPECT_THAT(absl::implicit_cast<absl::StatusOr<bool>>(
759
+ absl::StatusOr<const bool>(true)),
760
+ IsOkAndHolds(true));
761
+ EXPECT_THAT(absl::implicit_cast<absl::StatusOr<bool>>(
762
+ absl::StatusOr<const bool>(false)),
763
+ IsOkAndHolds(false));
764
+ EXPECT_THAT(absl::implicit_cast<absl::StatusOr<const bool>>(
765
+ absl::StatusOr<bool>(true)),
766
+ IsOkAndHolds(true));
767
+ EXPECT_THAT(absl::implicit_cast<absl::StatusOr<const bool>>(
768
+ absl::StatusOr<bool>(false)),
769
+ IsOkAndHolds(false));
770
+ EXPECT_THAT(absl::implicit_cast<absl::StatusOr<const std::string>>(
771
+ absl::StatusOr<std::string>("foo")),
772
+ IsOkAndHolds("foo"));
773
+ EXPECT_THAT(absl::implicit_cast<absl::StatusOr<std::string>>(
774
+ absl::StatusOr<const std::string>("foo")),
775
+ IsOkAndHolds("foo"));
776
+ EXPECT_THAT(
777
+ absl::implicit_cast<absl::StatusOr<std::shared_ptr<const std::string>>>(
778
+ absl::StatusOr<std::shared_ptr<std::string>>(
779
+ std::make_shared<std::string>("foo"))),
780
+ IsOkAndHolds(Pointee(std::string("foo"))));
781
+ }
782
+
783
+ TEST(StatusOr, ConstExplicitConstruction) {
784
+ EXPECT_THAT(absl::StatusOr<bool>(absl::StatusOr<const bool>(true)),
785
+ IsOkAndHolds(true));
786
+ EXPECT_THAT(absl::StatusOr<bool>(absl::StatusOr<const bool>(false)),
787
+ IsOkAndHolds(false));
788
+ EXPECT_THAT(absl::StatusOr<const bool>(absl::StatusOr<bool>(true)),
789
+ IsOkAndHolds(true));
790
+ EXPECT_THAT(absl::StatusOr<const bool>(absl::StatusOr<bool>(false)),
791
+ IsOkAndHolds(false));
792
+ }
793
+
794
+ struct ExplicitConstructibleFromInt {
795
+ int x;
796
+ explicit ExplicitConstructibleFromInt(int y) : x(y) {}
797
+ };
798
+
799
+ TEST(StatusOr, ExplicitConstruction) {
800
+ EXPECT_THAT(absl::StatusOr<ExplicitConstructibleFromInt>(10),
801
+ IsOkAndHolds(Field(&ExplicitConstructibleFromInt::x, 10)));
802
+ }
803
+
804
+ TEST(StatusOr, ImplicitConstruction) {
805
+ // Check implicit casting works.
806
+ auto status_or =
807
+ absl::implicit_cast<absl::StatusOr<absl::variant<int, std::string>>>(10);
808
+ EXPECT_THAT(status_or, IsOkAndHolds(VariantWith<int>(10)));
809
+ }
810
+
811
+ TEST(StatusOr, ImplicitConstructionFromInitliazerList) {
812
+ // Note: dropping the explicit std::initializer_list<int> is not supported
813
+ // by absl::StatusOr or absl::optional.
814
+ auto status_or =
815
+ absl::implicit_cast<absl::StatusOr<std::vector<int>>>({{10, 20, 30}});
816
+ EXPECT_THAT(status_or, IsOkAndHolds(ElementsAre(10, 20, 30)));
817
+ }
818
+
819
+ TEST(StatusOr, UniquePtrImplicitConstruction) {
820
+ auto status_or = absl::implicit_cast<absl::StatusOr<std::unique_ptr<Base1>>>(
821
+ absl::make_unique<Derived>());
822
+ EXPECT_THAT(status_or, IsOkAndHolds(Ne(nullptr)));
823
+ }
824
+
825
+ TEST(StatusOr, NestedStatusOrCopyAndMoveConstructorTests) {
826
+ absl::StatusOr<absl::StatusOr<CopyDetector>> status_or = CopyDetector(10);
827
+ absl::StatusOr<absl::StatusOr<CopyDetector>> status_error =
828
+ absl::InvalidArgumentError("foo");
829
+ EXPECT_THAT(status_or,
830
+ IsOkAndHolds(IsOkAndHolds(CopyDetectorHas(10, true, false))));
831
+ absl::StatusOr<absl::StatusOr<CopyDetector>> a = status_or;
832
+ EXPECT_THAT(a, IsOkAndHolds(IsOkAndHolds(CopyDetectorHas(10, false, true))));
833
+ absl::StatusOr<absl::StatusOr<CopyDetector>> a_err = status_error;
834
+ EXPECT_THAT(a_err, Not(IsOk()));
835
+
836
+ const absl::StatusOr<absl::StatusOr<CopyDetector>>& cref = status_or;
837
+ absl::StatusOr<absl::StatusOr<CopyDetector>> b = cref; // NOLINT
838
+ EXPECT_THAT(b, IsOkAndHolds(IsOkAndHolds(CopyDetectorHas(10, false, true))));
839
+ const absl::StatusOr<absl::StatusOr<CopyDetector>>& cref_err = status_error;
840
+ absl::StatusOr<absl::StatusOr<CopyDetector>> b_err = cref_err; // NOLINT
841
+ EXPECT_THAT(b_err, Not(IsOk()));
842
+
843
+ absl::StatusOr<absl::StatusOr<CopyDetector>> c = std::move(status_or);
844
+ EXPECT_THAT(c, IsOkAndHolds(IsOkAndHolds(CopyDetectorHas(10, true, false))));
845
+ absl::StatusOr<absl::StatusOr<CopyDetector>> c_err = std::move(status_error);
846
+ EXPECT_THAT(c_err, Not(IsOk()));
847
+ }
848
+
849
+ TEST(StatusOr, NestedStatusOrCopyAndMoveAssignment) {
850
+ absl::StatusOr<absl::StatusOr<CopyDetector>> status_or = CopyDetector(10);
851
+ absl::StatusOr<absl::StatusOr<CopyDetector>> status_error =
852
+ absl::InvalidArgumentError("foo");
853
+ absl::StatusOr<absl::StatusOr<CopyDetector>> a;
854
+ a = status_or;
855
+ EXPECT_THAT(a, IsOkAndHolds(IsOkAndHolds(CopyDetectorHas(10, false, true))));
856
+ a = status_error;
857
+ EXPECT_THAT(a, Not(IsOk()));
858
+
859
+ const absl::StatusOr<absl::StatusOr<CopyDetector>>& cref = status_or;
860
+ a = cref;
861
+ EXPECT_THAT(a, IsOkAndHolds(IsOkAndHolds(CopyDetectorHas(10, false, true))));
862
+ const absl::StatusOr<absl::StatusOr<CopyDetector>>& cref_err = status_error;
863
+ a = cref_err;
864
+ EXPECT_THAT(a, Not(IsOk()));
865
+ a = std::move(status_or);
866
+ EXPECT_THAT(a, IsOkAndHolds(IsOkAndHolds(CopyDetectorHas(10, true, false))));
867
+ a = std::move(status_error);
868
+ EXPECT_THAT(a, Not(IsOk()));
869
+ }
870
+
871
+ struct Copyable {
872
+ Copyable() {}
873
+ Copyable(const Copyable&) {}
874
+ Copyable& operator=(const Copyable&) { return *this; }
875
+ };
876
+
877
+ struct MoveOnly {
878
+ MoveOnly() {}
879
+ MoveOnly(MoveOnly&&) {}
880
+ MoveOnly& operator=(MoveOnly&&) { return *this; }
881
+ };
882
+
883
+ struct NonMovable {
884
+ NonMovable() {}
885
+ NonMovable(const NonMovable&) = delete;
886
+ NonMovable(NonMovable&&) = delete;
887
+ NonMovable& operator=(const NonMovable&) = delete;
888
+ NonMovable& operator=(NonMovable&&) = delete;
889
+ };
890
+
891
+ TEST(StatusOr, CopyAndMoveAbility) {
892
+ EXPECT_TRUE(std::is_copy_constructible<Copyable>::value);
893
+ EXPECT_TRUE(std::is_copy_assignable<Copyable>::value);
894
+ EXPECT_TRUE(std::is_move_constructible<Copyable>::value);
895
+ EXPECT_TRUE(std::is_move_assignable<Copyable>::value);
896
+ EXPECT_FALSE(std::is_copy_constructible<MoveOnly>::value);
897
+ EXPECT_FALSE(std::is_copy_assignable<MoveOnly>::value);
898
+ EXPECT_TRUE(std::is_move_constructible<MoveOnly>::value);
899
+ EXPECT_TRUE(std::is_move_assignable<MoveOnly>::value);
900
+ EXPECT_FALSE(std::is_copy_constructible<NonMovable>::value);
901
+ EXPECT_FALSE(std::is_copy_assignable<NonMovable>::value);
902
+ EXPECT_FALSE(std::is_move_constructible<NonMovable>::value);
903
+ EXPECT_FALSE(std::is_move_assignable<NonMovable>::value);
904
+ }
905
+
906
+ TEST(StatusOr, StatusOrAnyCopyAndMoveConstructorTests) {
907
+ absl::StatusOr<absl::any> status_or = CopyDetector(10);
908
+ absl::StatusOr<absl::any> status_error = absl::InvalidArgumentError("foo");
909
+ EXPECT_THAT(
910
+ status_or,
911
+ IsOkAndHolds(AnyWith<CopyDetector>(CopyDetectorHas(10, true, false))));
912
+ absl::StatusOr<absl::any> a = status_or;
913
+ EXPECT_THAT(
914
+ a, IsOkAndHolds(AnyWith<CopyDetector>(CopyDetectorHas(10, false, true))));
915
+ absl::StatusOr<absl::any> a_err = status_error;
916
+ EXPECT_THAT(a_err, Not(IsOk()));
917
+
918
+ const absl::StatusOr<absl::any>& cref = status_or;
919
+ // No lint for no-change copy.
920
+ absl::StatusOr<absl::any> b = cref; // NOLINT
921
+ EXPECT_THAT(
922
+ b, IsOkAndHolds(AnyWith<CopyDetector>(CopyDetectorHas(10, false, true))));
923
+ const absl::StatusOr<absl::any>& cref_err = status_error;
924
+ // No lint for no-change copy.
925
+ absl::StatusOr<absl::any> b_err = cref_err; // NOLINT
926
+ EXPECT_THAT(b_err, Not(IsOk()));
927
+
928
+ absl::StatusOr<absl::any> c = std::move(status_or);
929
+ EXPECT_THAT(
930
+ c, IsOkAndHolds(AnyWith<CopyDetector>(CopyDetectorHas(10, true, false))));
931
+ absl::StatusOr<absl::any> c_err = std::move(status_error);
932
+ EXPECT_THAT(c_err, Not(IsOk()));
933
+ }
934
+
935
+ TEST(StatusOr, StatusOrAnyCopyAndMoveAssignment) {
936
+ absl::StatusOr<absl::any> status_or = CopyDetector(10);
937
+ absl::StatusOr<absl::any> status_error = absl::InvalidArgumentError("foo");
938
+ absl::StatusOr<absl::any> a;
939
+ a = status_or;
940
+ EXPECT_THAT(
941
+ a, IsOkAndHolds(AnyWith<CopyDetector>(CopyDetectorHas(10, false, true))));
942
+ a = status_error;
943
+ EXPECT_THAT(a, Not(IsOk()));
944
+
945
+ const absl::StatusOr<absl::any>& cref = status_or;
946
+ a = cref;
947
+ EXPECT_THAT(
948
+ a, IsOkAndHolds(AnyWith<CopyDetector>(CopyDetectorHas(10, false, true))));
949
+ const absl::StatusOr<absl::any>& cref_err = status_error;
950
+ a = cref_err;
951
+ EXPECT_THAT(a, Not(IsOk()));
952
+ a = std::move(status_or);
953
+ EXPECT_THAT(
954
+ a, IsOkAndHolds(AnyWith<CopyDetector>(CopyDetectorHas(10, true, false))));
955
+ a = std::move(status_error);
956
+ EXPECT_THAT(a, Not(IsOk()));
957
+ }
958
+
959
+ TEST(StatusOr, StatusOrCopyAndMoveTestsConstructor) {
960
+ absl::StatusOr<CopyDetector> status_or(10);
961
+ ASSERT_THAT(status_or, IsOkAndHolds(CopyDetectorHas(10, false, false)));
962
+ absl::StatusOr<CopyDetector> a(status_or);
963
+ EXPECT_THAT(a, IsOkAndHolds(CopyDetectorHas(10, false, true)));
964
+ const absl::StatusOr<CopyDetector>& cref = status_or;
965
+ absl::StatusOr<CopyDetector> b(cref); // NOLINT
966
+ EXPECT_THAT(b, IsOkAndHolds(CopyDetectorHas(10, false, true)));
967
+ absl::StatusOr<CopyDetector> c(std::move(status_or));
968
+ EXPECT_THAT(c, IsOkAndHolds(CopyDetectorHas(10, true, false)));
969
+ }
970
+
971
+ TEST(StatusOr, StatusOrCopyAndMoveTestsAssignment) {
972
+ absl::StatusOr<CopyDetector> status_or(10);
973
+ ASSERT_THAT(status_or, IsOkAndHolds(CopyDetectorHas(10, false, false)));
974
+ absl::StatusOr<CopyDetector> a;
975
+ a = status_or;
976
+ EXPECT_THAT(a, IsOkAndHolds(CopyDetectorHas(10, false, true)));
977
+ const absl::StatusOr<CopyDetector>& cref = status_or;
978
+ absl::StatusOr<CopyDetector> b;
979
+ b = cref;
980
+ EXPECT_THAT(b, IsOkAndHolds(CopyDetectorHas(10, false, true)));
981
+ absl::StatusOr<CopyDetector> c;
982
+ c = std::move(status_or);
983
+ EXPECT_THAT(c, IsOkAndHolds(CopyDetectorHas(10, true, false)));
984
+ }
985
+
986
+ TEST(StatusOr, AbslAnyAssignment) {
987
+ EXPECT_FALSE((std::is_assignable<absl::StatusOr<absl::any>,
988
+ absl::StatusOr<int>>::value));
989
+ absl::StatusOr<absl::any> status_or;
990
+ status_or = absl::InvalidArgumentError("foo");
991
+ EXPECT_THAT(status_or, Not(IsOk()));
992
+ }
993
+
994
+ TEST(StatusOr, ImplicitAssignment) {
995
+ absl::StatusOr<absl::variant<int, std::string>> status_or;
996
+ status_or = 10;
997
+ EXPECT_THAT(status_or, IsOkAndHolds(VariantWith<int>(10)));
998
+ }
999
+
1000
+ TEST(StatusOr, SelfDirectInitAssignment) {
1001
+ absl::StatusOr<std::vector<int>> status_or = {{10, 20, 30}};
1002
+ status_or = *status_or;
1003
+ EXPECT_THAT(status_or, IsOkAndHolds(ElementsAre(10, 20, 30)));
1004
+ }
1005
+
1006
+ TEST(StatusOr, ImplicitCastFromInitializerList) {
1007
+ absl::StatusOr<std::vector<int>> status_or = {{10, 20, 30}};
1008
+ EXPECT_THAT(status_or, IsOkAndHolds(ElementsAre(10, 20, 30)));
1009
+ }
1010
+
1011
+ TEST(StatusOr, UniquePtrImplicitAssignment) {
1012
+ absl::StatusOr<std::unique_ptr<Base1>> status_or;
1013
+ status_or = absl::make_unique<Derived>();
1014
+ EXPECT_THAT(status_or, IsOkAndHolds(Ne(nullptr)));
1015
+ }
1016
+
1017
+ TEST(StatusOr, Pointer) {
1018
+ struct A {};
1019
+ struct B : public A {};
1020
+ struct C : private A {};
1021
+
1022
+ EXPECT_TRUE((std::is_constructible<absl::StatusOr<A*>, B*>::value));
1023
+ EXPECT_TRUE((std::is_convertible<B*, absl::StatusOr<A*>>::value));
1024
+ EXPECT_FALSE((std::is_constructible<absl::StatusOr<A*>, C*>::value));
1025
+ EXPECT_FALSE((std::is_convertible<C*, absl::StatusOr<A*>>::value));
1026
+ }
1027
+
1028
+ TEST(StatusOr, TestAssignmentStatusNotOkConverting) {
1029
+ // Copy assignment
1030
+ {
1031
+ const absl::Status expected = absl::CancelledError();
1032
+ absl::StatusOr<int> source(expected);
1033
+
1034
+ absl::StatusOr<double> target;
1035
+ target = source;
1036
+
1037
+ EXPECT_FALSE(target.ok());
1038
+ EXPECT_EQ(expected, target.status());
1039
+
1040
+ EXPECT_FALSE(source.ok());
1041
+ EXPECT_EQ(expected, source.status());
1042
+ }
1043
+
1044
+ // Move assignment
1045
+ {
1046
+ const absl::Status expected = absl::CancelledError();
1047
+ absl::StatusOr<int> source(expected);
1048
+
1049
+ absl::StatusOr<double> target;
1050
+ target = std::move(source);
1051
+
1052
+ EXPECT_FALSE(target.ok());
1053
+ EXPECT_EQ(expected, target.status());
1054
+
1055
+ EXPECT_FALSE(source.ok());
1056
+ EXPECT_EQ(source.status().code(), absl::StatusCode::kInternal);
1057
+ }
1058
+ }
1059
+
1060
+ TEST(StatusOr, SelfAssignment) {
1061
+ // Copy-assignment, status OK
1062
+ {
1063
+ // A string long enough that it's likely to defeat any inline representation
1064
+ // optimization.
1065
+ const std::string long_str(128, 'a');
1066
+
1067
+ absl::StatusOr<std::string> so = long_str;
1068
+ so = *&so;
1069
+
1070
+ ASSERT_TRUE(so.ok());
1071
+ EXPECT_OK(so.status());
1072
+ EXPECT_EQ(long_str, *so);
1073
+ }
1074
+
1075
+ // Copy-assignment, error status
1076
+ {
1077
+ absl::StatusOr<int> so = absl::NotFoundError("taco");
1078
+ so = *&so;
1079
+
1080
+ EXPECT_FALSE(so.ok());
1081
+ EXPECT_EQ(so.status().code(), absl::StatusCode::kNotFound);
1082
+ EXPECT_EQ(so.status().message(), "taco");
1083
+ }
1084
+
1085
+ // Move-assignment with copyable type, status OK
1086
+ {
1087
+ absl::StatusOr<int> so = 17;
1088
+
1089
+ // Fool the compiler, which otherwise complains.
1090
+ auto& same = so;
1091
+ so = std::move(same);
1092
+
1093
+ ASSERT_TRUE(so.ok());
1094
+ EXPECT_OK(so.status());
1095
+ EXPECT_EQ(17, *so);
1096
+ }
1097
+
1098
+ // Move-assignment with copyable type, error status
1099
+ {
1100
+ absl::StatusOr<int> so = absl::NotFoundError("taco");
1101
+
1102
+ // Fool the compiler, which otherwise complains.
1103
+ auto& same = so;
1104
+ so = std::move(same);
1105
+
1106
+ EXPECT_FALSE(so.ok());
1107
+ EXPECT_EQ(so.status().code(), absl::StatusCode::kNotFound);
1108
+ EXPECT_EQ(so.status().message(), "taco");
1109
+ }
1110
+
1111
+ // Move-assignment with non-copyable type, status OK
1112
+ {
1113
+ const auto raw = new int(17);
1114
+ absl::StatusOr<std::unique_ptr<int>> so = absl::WrapUnique(raw);
1115
+
1116
+ // Fool the compiler, which otherwise complains.
1117
+ auto& same = so;
1118
+ so = std::move(same);
1119
+
1120
+ ASSERT_TRUE(so.ok());
1121
+ EXPECT_OK(so.status());
1122
+ EXPECT_EQ(raw, so->get());
1123
+ }
1124
+
1125
+ // Move-assignment with non-copyable type, error status
1126
+ {
1127
+ absl::StatusOr<std::unique_ptr<int>> so = absl::NotFoundError("taco");
1128
+
1129
+ // Fool the compiler, which otherwise complains.
1130
+ auto& same = so;
1131
+ so = std::move(same);
1132
+
1133
+ EXPECT_FALSE(so.ok());
1134
+ EXPECT_EQ(so.status().code(), absl::StatusCode::kNotFound);
1135
+ EXPECT_EQ(so.status().message(), "taco");
1136
+ }
1137
+ }
1138
+
1139
+ // These types form the overload sets of the constructors and the assignment
1140
+ // operators of `MockValue`. They distinguish construction from assignment,
1141
+ // lvalue from rvalue.
1142
+ struct FromConstructibleAssignableLvalue {};
1143
+ struct FromConstructibleAssignableRvalue {};
1144
+ struct FromImplicitConstructibleOnly {};
1145
+ struct FromAssignableOnly {};
1146
+
1147
+ // This class is for testing the forwarding value assignments of `StatusOr`.
1148
+ // `from_rvalue` indicates whether the constructor or the assignment taking
1149
+ // rvalue reference is called. `from_assignment` indicates whether any
1150
+ // assignment is called.
1151
+ struct MockValue {
1152
+ // Constructs `MockValue` from `FromConstructibleAssignableLvalue`.
1153
+ MockValue(const FromConstructibleAssignableLvalue&) // NOLINT
1154
+ : from_rvalue(false), assigned(false) {}
1155
+ // Constructs `MockValue` from `FromConstructibleAssignableRvalue`.
1156
+ MockValue(FromConstructibleAssignableRvalue&&) // NOLINT
1157
+ : from_rvalue(true), assigned(false) {}
1158
+ // Constructs `MockValue` from `FromImplicitConstructibleOnly`.
1159
+ // `MockValue` is not assignable from `FromImplicitConstructibleOnly`.
1160
+ MockValue(const FromImplicitConstructibleOnly&) // NOLINT
1161
+ : from_rvalue(false), assigned(false) {}
1162
+ // Assigns `FromConstructibleAssignableLvalue`.
1163
+ MockValue& operator=(const FromConstructibleAssignableLvalue&) {
1164
+ from_rvalue = false;
1165
+ assigned = true;
1166
+ return *this;
1167
+ }
1168
+ // Assigns `FromConstructibleAssignableRvalue` (rvalue only).
1169
+ MockValue& operator=(FromConstructibleAssignableRvalue&&) {
1170
+ from_rvalue = true;
1171
+ assigned = true;
1172
+ return *this;
1173
+ }
1174
+ // Assigns `FromAssignableOnly`, but not constructible from
1175
+ // `FromAssignableOnly`.
1176
+ MockValue& operator=(const FromAssignableOnly&) {
1177
+ from_rvalue = false;
1178
+ assigned = true;
1179
+ return *this;
1180
+ }
1181
+ bool from_rvalue;
1182
+ bool assigned;
1183
+ };
1184
+
1185
+ // operator=(U&&)
1186
+ TEST(StatusOr, PerfectForwardingAssignment) {
1187
+ // U == T
1188
+ constexpr int kValue1 = 10, kValue2 = 20;
1189
+ absl::StatusOr<CopyDetector> status_or;
1190
+ CopyDetector lvalue(kValue1);
1191
+ status_or = lvalue;
1192
+ EXPECT_THAT(status_or, IsOkAndHolds(CopyDetectorHas(kValue1, false, true)));
1193
+ status_or = CopyDetector(kValue2);
1194
+ EXPECT_THAT(status_or, IsOkAndHolds(CopyDetectorHas(kValue2, true, false)));
1195
+
1196
+ // U != T
1197
+ EXPECT_TRUE(
1198
+ (std::is_assignable<absl::StatusOr<MockValue>&,
1199
+ const FromConstructibleAssignableLvalue&>::value));
1200
+ EXPECT_TRUE((std::is_assignable<absl::StatusOr<MockValue>&,
1201
+ FromConstructibleAssignableLvalue&&>::value));
1202
+ EXPECT_FALSE(
1203
+ (std::is_assignable<absl::StatusOr<MockValue>&,
1204
+ const FromConstructibleAssignableRvalue&>::value));
1205
+ EXPECT_TRUE((std::is_assignable<absl::StatusOr<MockValue>&,
1206
+ FromConstructibleAssignableRvalue&&>::value));
1207
+ EXPECT_TRUE(
1208
+ (std::is_assignable<absl::StatusOr<MockValue>&,
1209
+ const FromImplicitConstructibleOnly&>::value));
1210
+ EXPECT_FALSE((std::is_assignable<absl::StatusOr<MockValue>&,
1211
+ const FromAssignableOnly&>::value));
1212
+
1213
+ absl::StatusOr<MockValue> from_lvalue(FromConstructibleAssignableLvalue{});
1214
+ EXPECT_FALSE(from_lvalue->from_rvalue);
1215
+ EXPECT_FALSE(from_lvalue->assigned);
1216
+ from_lvalue = FromConstructibleAssignableLvalue{};
1217
+ EXPECT_FALSE(from_lvalue->from_rvalue);
1218
+ EXPECT_TRUE(from_lvalue->assigned);
1219
+
1220
+ absl::StatusOr<MockValue> from_rvalue(FromConstructibleAssignableRvalue{});
1221
+ EXPECT_TRUE(from_rvalue->from_rvalue);
1222
+ EXPECT_FALSE(from_rvalue->assigned);
1223
+ from_rvalue = FromConstructibleAssignableRvalue{};
1224
+ EXPECT_TRUE(from_rvalue->from_rvalue);
1225
+ EXPECT_TRUE(from_rvalue->assigned);
1226
+
1227
+ absl::StatusOr<MockValue> from_implicit_constructible(
1228
+ FromImplicitConstructibleOnly{});
1229
+ EXPECT_FALSE(from_implicit_constructible->from_rvalue);
1230
+ EXPECT_FALSE(from_implicit_constructible->assigned);
1231
+ // construct a temporary `StatusOr` object and invoke the `StatusOr` move
1232
+ // assignment operator.
1233
+ from_implicit_constructible = FromImplicitConstructibleOnly{};
1234
+ EXPECT_FALSE(from_implicit_constructible->from_rvalue);
1235
+ EXPECT_FALSE(from_implicit_constructible->assigned);
1236
+ }
1237
+
1238
+ TEST(StatusOr, TestStatus) {
1239
+ absl::StatusOr<int> good(4);
1240
+ EXPECT_TRUE(good.ok());
1241
+ absl::StatusOr<int> bad(absl::CancelledError());
1242
+ EXPECT_FALSE(bad.ok());
1243
+ EXPECT_EQ(bad.status().code(), absl::StatusCode::kCancelled);
1244
+ }
1245
+
1246
+ TEST(StatusOr, OperatorStarRefQualifiers) {
1247
+ static_assert(
1248
+ std::is_same<const int&,
1249
+ decltype(*std::declval<const absl::StatusOr<int>&>())>(),
1250
+ "Unexpected ref-qualifiers");
1251
+ static_assert(
1252
+ std::is_same<int&, decltype(*std::declval<absl::StatusOr<int>&>())>(),
1253
+ "Unexpected ref-qualifiers");
1254
+ static_assert(
1255
+ std::is_same<const int&&,
1256
+ decltype(*std::declval<const absl::StatusOr<int>&&>())>(),
1257
+ "Unexpected ref-qualifiers");
1258
+ static_assert(
1259
+ std::is_same<int&&, decltype(*std::declval<absl::StatusOr<int>&&>())>(),
1260
+ "Unexpected ref-qualifiers");
1261
+ }
1262
+
1263
+ TEST(StatusOr, OperatorStar) {
1264
+ const absl::StatusOr<std::string> const_lvalue("hello");
1265
+ EXPECT_EQ("hello", *const_lvalue);
1266
+
1267
+ absl::StatusOr<std::string> lvalue("hello");
1268
+ EXPECT_EQ("hello", *lvalue);
1269
+
1270
+ // Note: Recall that std::move() is equivalent to a static_cast to an rvalue
1271
+ // reference type.
1272
+ const absl::StatusOr<std::string> const_rvalue("hello");
1273
+ EXPECT_EQ("hello", *std::move(const_rvalue)); // NOLINT
1274
+
1275
+ absl::StatusOr<std::string> rvalue("hello");
1276
+ EXPECT_EQ("hello", *std::move(rvalue));
1277
+ }
1278
+
1279
+ TEST(StatusOr, OperatorArrowQualifiers) {
1280
+ static_assert(
1281
+ std::is_same<
1282
+ const int*,
1283
+ decltype(std::declval<const absl::StatusOr<int>&>().operator->())>(),
1284
+ "Unexpected qualifiers");
1285
+ static_assert(
1286
+ std::is_same<
1287
+ int*, decltype(std::declval<absl::StatusOr<int>&>().operator->())>(),
1288
+ "Unexpected qualifiers");
1289
+ static_assert(
1290
+ std::is_same<
1291
+ const int*,
1292
+ decltype(std::declval<const absl::StatusOr<int>&&>().operator->())>(),
1293
+ "Unexpected qualifiers");
1294
+ static_assert(
1295
+ std::is_same<
1296
+ int*, decltype(std::declval<absl::StatusOr<int>&&>().operator->())>(),
1297
+ "Unexpected qualifiers");
1298
+ }
1299
+
1300
+ TEST(StatusOr, OperatorArrow) {
1301
+ const absl::StatusOr<std::string> const_lvalue("hello");
1302
+ EXPECT_EQ(std::string("hello"), const_lvalue->c_str());
1303
+
1304
+ absl::StatusOr<std::string> lvalue("hello");
1305
+ EXPECT_EQ(std::string("hello"), lvalue->c_str());
1306
+ }
1307
+
1308
+ TEST(StatusOr, RValueStatus) {
1309
+ absl::StatusOr<int> so(absl::NotFoundError("taco"));
1310
+ const absl::Status s = std::move(so).status();
1311
+
1312
+ EXPECT_EQ(s.code(), absl::StatusCode::kNotFound);
1313
+ EXPECT_EQ(s.message(), "taco");
1314
+
1315
+ // Check that !ok() still implies !status().ok(), even after moving out of the
1316
+ // object. See the note on the rvalue ref-qualified status method.
1317
+ EXPECT_FALSE(so.ok()); // NOLINT
1318
+ EXPECT_FALSE(so.status().ok());
1319
+ EXPECT_EQ(so.status().code(), absl::StatusCode::kInternal);
1320
+ EXPECT_EQ(so.status().message(), "Status accessed after move.");
1321
+ }
1322
+
1323
+ TEST(StatusOr, TestValue) {
1324
+ const int kI = 4;
1325
+ absl::StatusOr<int> thing(kI);
1326
+ EXPECT_EQ(kI, *thing);
1327
+ }
1328
+
1329
+ TEST(StatusOr, TestValueConst) {
1330
+ const int kI = 4;
1331
+ const absl::StatusOr<int> thing(kI);
1332
+ EXPECT_EQ(kI, *thing);
1333
+ }
1334
+
1335
+ TEST(StatusOr, TestPointerDefaultCtor) {
1336
+ absl::StatusOr<int*> thing;
1337
+ EXPECT_FALSE(thing.ok());
1338
+ EXPECT_EQ(thing.status().code(), absl::StatusCode::kUnknown);
1339
+ }
1340
+
1341
+ TEST(StatusOr, TestPointerStatusCtor) {
1342
+ absl::StatusOr<int*> thing(absl::CancelledError());
1343
+ EXPECT_FALSE(thing.ok());
1344
+ EXPECT_EQ(thing.status().code(), absl::StatusCode::kCancelled);
1345
+ }
1346
+
1347
+ TEST(StatusOr, TestPointerValueCtor) {
1348
+ const int kI = 4;
1349
+
1350
+ // Construction from a non-null pointer
1351
+ {
1352
+ absl::StatusOr<const int*> so(&kI);
1353
+ EXPECT_TRUE(so.ok());
1354
+ EXPECT_OK(so.status());
1355
+ EXPECT_EQ(&kI, *so);
1356
+ }
1357
+
1358
+ // Construction from a null pointer constant
1359
+ {
1360
+ absl::StatusOr<const int*> so(nullptr);
1361
+ EXPECT_TRUE(so.ok());
1362
+ EXPECT_OK(so.status());
1363
+ EXPECT_EQ(nullptr, *so);
1364
+ }
1365
+
1366
+ // Construction from a non-literal null pointer
1367
+ {
1368
+ const int* const p = nullptr;
1369
+
1370
+ absl::StatusOr<const int*> so(p);
1371
+ EXPECT_TRUE(so.ok());
1372
+ EXPECT_OK(so.status());
1373
+ EXPECT_EQ(nullptr, *so);
1374
+ }
1375
+ }
1376
+
1377
+ TEST(StatusOr, TestPointerCopyCtorStatusOk) {
1378
+ const int kI = 0;
1379
+ absl::StatusOr<const int*> original(&kI);
1380
+ absl::StatusOr<const int*> copy(original);
1381
+ EXPECT_OK(copy.status());
1382
+ EXPECT_EQ(*original, *copy);
1383
+ }
1384
+
1385
+ TEST(StatusOr, TestPointerCopyCtorStatusNotOk) {
1386
+ absl::StatusOr<int*> original(absl::CancelledError());
1387
+ absl::StatusOr<int*> copy(original);
1388
+ EXPECT_EQ(copy.status().code(), absl::StatusCode::kCancelled);
1389
+ }
1390
+
1391
+ TEST(StatusOr, TestPointerCopyCtorStatusOKConverting) {
1392
+ Derived derived;
1393
+ absl::StatusOr<Derived*> original(&derived);
1394
+ absl::StatusOr<Base2*> copy(original);
1395
+ EXPECT_OK(copy.status());
1396
+ EXPECT_EQ(static_cast<const Base2*>(*original), *copy);
1397
+ }
1398
+
1399
+ TEST(StatusOr, TestPointerCopyCtorStatusNotOkConverting) {
1400
+ absl::StatusOr<Derived*> original(absl::CancelledError());
1401
+ absl::StatusOr<Base2*> copy(original);
1402
+ EXPECT_EQ(copy.status().code(), absl::StatusCode::kCancelled);
1403
+ }
1404
+
1405
+ TEST(StatusOr, TestPointerAssignmentStatusOk) {
1406
+ const int kI = 0;
1407
+ absl::StatusOr<const int*> source(&kI);
1408
+ absl::StatusOr<const int*> target;
1409
+ target = source;
1410
+ EXPECT_OK(target.status());
1411
+ EXPECT_EQ(*source, *target);
1412
+ }
1413
+
1414
+ TEST(StatusOr, TestPointerAssignmentStatusNotOk) {
1415
+ absl::StatusOr<int*> source(absl::CancelledError());
1416
+ absl::StatusOr<int*> target;
1417
+ target = source;
1418
+ EXPECT_EQ(target.status().code(), absl::StatusCode::kCancelled);
1419
+ }
1420
+
1421
+ TEST(StatusOr, TestPointerAssignmentStatusOKConverting) {
1422
+ Derived derived;
1423
+ absl::StatusOr<Derived*> source(&derived);
1424
+ absl::StatusOr<Base2*> target;
1425
+ target = source;
1426
+ EXPECT_OK(target.status());
1427
+ EXPECT_EQ(static_cast<const Base2*>(*source), *target);
1428
+ }
1429
+
1430
+ TEST(StatusOr, TestPointerAssignmentStatusNotOkConverting) {
1431
+ absl::StatusOr<Derived*> source(absl::CancelledError());
1432
+ absl::StatusOr<Base2*> target;
1433
+ target = source;
1434
+ EXPECT_EQ(target.status(), source.status());
1435
+ }
1436
+
1437
+ TEST(StatusOr, TestPointerStatus) {
1438
+ const int kI = 0;
1439
+ absl::StatusOr<const int*> good(&kI);
1440
+ EXPECT_TRUE(good.ok());
1441
+ absl::StatusOr<const int*> bad(absl::CancelledError());
1442
+ EXPECT_EQ(bad.status().code(), absl::StatusCode::kCancelled);
1443
+ }
1444
+
1445
+ TEST(StatusOr, TestPointerValue) {
1446
+ const int kI = 0;
1447
+ absl::StatusOr<const int*> thing(&kI);
1448
+ EXPECT_EQ(&kI, *thing);
1449
+ }
1450
+
1451
+ TEST(StatusOr, TestPointerValueConst) {
1452
+ const int kI = 0;
1453
+ const absl::StatusOr<const int*> thing(&kI);
1454
+ EXPECT_EQ(&kI, *thing);
1455
+ }
1456
+
1457
+ TEST(StatusOr, StatusOrVectorOfUniquePointerCanReserveAndResize) {
1458
+ using EvilType = std::vector<std::unique_ptr<int>>;
1459
+ static_assert(std::is_copy_constructible<EvilType>::value, "");
1460
+ std::vector<::absl::StatusOr<EvilType>> v(5);
1461
+ v.reserve(v.capacity() + 10);
1462
+ v.resize(v.capacity() + 10);
1463
+ }
1464
+
1465
+ TEST(StatusOr, ConstPayload) {
1466
+ // A reduced version of a problematic type found in the wild. All of the
1467
+ // operations below should compile.
1468
+ absl::StatusOr<const int> a;
1469
+
1470
+ // Copy-construction
1471
+ absl::StatusOr<const int> b(a);
1472
+
1473
+ // Copy-assignment
1474
+ EXPECT_FALSE(std::is_copy_assignable<absl::StatusOr<const int>>::value);
1475
+
1476
+ // Move-construction
1477
+ absl::StatusOr<const int> c(std::move(a));
1478
+
1479
+ // Move-assignment
1480
+ EXPECT_FALSE(std::is_move_assignable<absl::StatusOr<const int>>::value);
1481
+ }
1482
+
1483
+ TEST(StatusOr, MapToStatusOrUniquePtr) {
1484
+ // A reduced version of a problematic type found in the wild. All of the
1485
+ // operations below should compile.
1486
+ using MapType = std::map<std::string, absl::StatusOr<std::unique_ptr<int>>>;
1487
+
1488
+ MapType a;
1489
+
1490
+ // Move-construction
1491
+ MapType b(std::move(a));
1492
+
1493
+ // Move-assignment
1494
+ a = std::move(b);
1495
+ }
1496
+
1497
+ TEST(StatusOr, ValueOrOk) {
1498
+ const absl::StatusOr<int> status_or = 0;
1499
+ EXPECT_EQ(status_or.value_or(-1), 0);
1500
+ }
1501
+
1502
+ TEST(StatusOr, ValueOrDefault) {
1503
+ const absl::StatusOr<int> status_or = absl::CancelledError();
1504
+ EXPECT_EQ(status_or.value_or(-1), -1);
1505
+ }
1506
+
1507
+ TEST(StatusOr, MoveOnlyValueOrOk) {
1508
+ EXPECT_THAT(absl::StatusOr<std::unique_ptr<int>>(absl::make_unique<int>(0))
1509
+ .value_or(absl::make_unique<int>(-1)),
1510
+ Pointee(0));
1511
+ }
1512
+
1513
+ TEST(StatusOr, MoveOnlyValueOrDefault) {
1514
+ EXPECT_THAT(absl::StatusOr<std::unique_ptr<int>>(absl::CancelledError())
1515
+ .value_or(absl::make_unique<int>(-1)),
1516
+ Pointee(-1));
1517
+ }
1518
+
1519
+ static absl::StatusOr<int> MakeStatus() { return 100; }
1520
+
1521
+ TEST(StatusOr, TestIgnoreError) { MakeStatus().IgnoreError(); }
1522
+
1523
+ TEST(StatusOr, EqualityOperator) {
1524
+ constexpr size_t kNumCases = 4;
1525
+ std::array<absl::StatusOr<int>, kNumCases> group1 = {
1526
+ absl::StatusOr<int>(1), absl::StatusOr<int>(2),
1527
+ absl::StatusOr<int>(absl::InvalidArgumentError("msg")),
1528
+ absl::StatusOr<int>(absl::InternalError("msg"))};
1529
+ std::array<absl::StatusOr<int>, kNumCases> group2 = {
1530
+ absl::StatusOr<int>(1), absl::StatusOr<int>(2),
1531
+ absl::StatusOr<int>(absl::InvalidArgumentError("msg")),
1532
+ absl::StatusOr<int>(absl::InternalError("msg"))};
1533
+ for (size_t i = 0; i < kNumCases; ++i) {
1534
+ for (size_t j = 0; j < kNumCases; ++j) {
1535
+ if (i == j) {
1536
+ EXPECT_TRUE(group1[i] == group2[j]);
1537
+ EXPECT_FALSE(group1[i] != group2[j]);
1538
+ } else {
1539
+ EXPECT_FALSE(group1[i] == group2[j]);
1540
+ EXPECT_TRUE(group1[i] != group2[j]);
1541
+ }
1542
+ }
1543
+ }
1544
+ }
1545
+
1546
+ struct MyType {
1547
+ bool operator==(const MyType&) const { return true; }
1548
+ };
1549
+
1550
+ enum class ConvTraits { kNone = 0, kImplicit = 1, kExplicit = 2 };
1551
+
1552
+ // This class has conversion operator to `StatusOr<T>` based on value of
1553
+ // `conv_traits`.
1554
+ template <typename T, ConvTraits conv_traits = ConvTraits::kNone>
1555
+ struct StatusOrConversionBase {};
1556
+
1557
+ template <typename T>
1558
+ struct StatusOrConversionBase<T, ConvTraits::kImplicit> {
1559
+ operator absl::StatusOr<T>() const& { // NOLINT
1560
+ return absl::InvalidArgumentError("conversion to absl::StatusOr");
1561
+ }
1562
+ operator absl::StatusOr<T>() && { // NOLINT
1563
+ return absl::InvalidArgumentError("conversion to absl::StatusOr");
1564
+ }
1565
+ };
1566
+
1567
+ template <typename T>
1568
+ struct StatusOrConversionBase<T, ConvTraits::kExplicit> {
1569
+ explicit operator absl::StatusOr<T>() const& {
1570
+ return absl::InvalidArgumentError("conversion to absl::StatusOr");
1571
+ }
1572
+ explicit operator absl::StatusOr<T>() && {
1573
+ return absl::InvalidArgumentError("conversion to absl::StatusOr");
1574
+ }
1575
+ };
1576
+
1577
+ // This class has conversion operator to `T` based on the value of
1578
+ // `conv_traits`.
1579
+ template <typename T, ConvTraits conv_traits = ConvTraits::kNone>
1580
+ struct ConversionBase {};
1581
+
1582
+ template <typename T>
1583
+ struct ConversionBase<T, ConvTraits::kImplicit> {
1584
+ operator T() const& { return t; } // NOLINT
1585
+ operator T() && { return std::move(t); } // NOLINT
1586
+ T t;
1587
+ };
1588
+
1589
+ template <typename T>
1590
+ struct ConversionBase<T, ConvTraits::kExplicit> {
1591
+ explicit operator T() const& { return t; }
1592
+ explicit operator T() && { return std::move(t); }
1593
+ T t;
1594
+ };
1595
+
1596
+ // This class has conversion operator to `absl::Status` based on the value of
1597
+ // `conv_traits`.
1598
+ template <ConvTraits conv_traits = ConvTraits::kNone>
1599
+ struct StatusConversionBase {};
1600
+
1601
+ template <>
1602
+ struct StatusConversionBase<ConvTraits::kImplicit> {
1603
+ operator absl::Status() const& { // NOLINT
1604
+ return absl::InternalError("conversion to Status");
1605
+ }
1606
+ operator absl::Status() && { // NOLINT
1607
+ return absl::InternalError("conversion to Status");
1608
+ }
1609
+ };
1610
+
1611
+ template <>
1612
+ struct StatusConversionBase<ConvTraits::kExplicit> {
1613
+ explicit operator absl::Status() const& { // NOLINT
1614
+ return absl::InternalError("conversion to Status");
1615
+ }
1616
+ explicit operator absl::Status() && { // NOLINT
1617
+ return absl::InternalError("conversion to Status");
1618
+ }
1619
+ };
1620
+
1621
+ static constexpr int kConvToStatus = 1;
1622
+ static constexpr int kConvToStatusOr = 2;
1623
+ static constexpr int kConvToT = 4;
1624
+ static constexpr int kConvExplicit = 8;
1625
+
1626
+ constexpr ConvTraits GetConvTraits(int bit, int config) {
1627
+ return (config & bit) == 0
1628
+ ? ConvTraits::kNone
1629
+ : ((config & kConvExplicit) == 0 ? ConvTraits::kImplicit
1630
+ : ConvTraits::kExplicit);
1631
+ }
1632
+
1633
+ // This class conditionally has conversion operator to `absl::Status`, `T`,
1634
+ // `StatusOr<T>`, based on values of the template parameters.
1635
+ template <typename T, int config>
1636
+ struct CustomType
1637
+ : StatusOrConversionBase<T, GetConvTraits(kConvToStatusOr, config)>,
1638
+ ConversionBase<T, GetConvTraits(kConvToT, config)>,
1639
+ StatusConversionBase<GetConvTraits(kConvToStatus, config)> {};
1640
+
1641
+ struct ConvertibleToAnyStatusOr {
1642
+ template <typename T>
1643
+ operator absl::StatusOr<T>() const { // NOLINT
1644
+ return absl::InvalidArgumentError("Conversion to absl::StatusOr");
1645
+ }
1646
+ };
1647
+
1648
+ // Test the rank of overload resolution for `StatusOr<T>` constructor and
1649
+ // assignment, from highest to lowest:
1650
+ // 1. T/Status
1651
+ // 2. U that has conversion operator to absl::StatusOr<T>
1652
+ // 3. U that is convertible to Status
1653
+ // 4. U that is convertible to T
1654
+ TEST(StatusOr, ConstructionFromT) {
1655
+ // Construct absl::StatusOr<T> from T when T is convertible to
1656
+ // absl::StatusOr<T>
1657
+ {
1658
+ ConvertibleToAnyStatusOr v;
1659
+ absl::StatusOr<ConvertibleToAnyStatusOr> statusor(v);
1660
+ EXPECT_TRUE(statusor.ok());
1661
+ }
1662
+ {
1663
+ ConvertibleToAnyStatusOr v;
1664
+ absl::StatusOr<ConvertibleToAnyStatusOr> statusor = v;
1665
+ EXPECT_TRUE(statusor.ok());
1666
+ }
1667
+ // Construct absl::StatusOr<T> from T when T is explicitly convertible to
1668
+ // Status
1669
+ {
1670
+ CustomType<MyType, kConvToStatus | kConvExplicit> v;
1671
+ absl::StatusOr<CustomType<MyType, kConvToStatus | kConvExplicit>> statusor(
1672
+ v);
1673
+ EXPECT_TRUE(statusor.ok());
1674
+ }
1675
+ {
1676
+ CustomType<MyType, kConvToStatus | kConvExplicit> v;
1677
+ absl::StatusOr<CustomType<MyType, kConvToStatus | kConvExplicit>> statusor =
1678
+ v;
1679
+ EXPECT_TRUE(statusor.ok());
1680
+ }
1681
+ }
1682
+
1683
+ // Construct absl::StatusOr<T> from U when U is explicitly convertible to T
1684
+ TEST(StatusOr, ConstructionFromTypeConvertibleToT) {
1685
+ {
1686
+ CustomType<MyType, kConvToT | kConvExplicit> v;
1687
+ absl::StatusOr<MyType> statusor(v);
1688
+ EXPECT_TRUE(statusor.ok());
1689
+ }
1690
+ {
1691
+ CustomType<MyType, kConvToT> v;
1692
+ absl::StatusOr<MyType> statusor = v;
1693
+ EXPECT_TRUE(statusor.ok());
1694
+ }
1695
+ }
1696
+
1697
+ // Construct absl::StatusOr<T> from U when U has explicit conversion operator to
1698
+ // absl::StatusOr<T>
1699
+ TEST(StatusOr, ConstructionFromTypeWithConversionOperatorToStatusOrT) {
1700
+ {
1701
+ CustomType<MyType, kConvToStatusOr | kConvExplicit> v;
1702
+ absl::StatusOr<MyType> statusor(v);
1703
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1704
+ }
1705
+ {
1706
+ CustomType<MyType, kConvToT | kConvToStatusOr | kConvExplicit> v;
1707
+ absl::StatusOr<MyType> statusor(v);
1708
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1709
+ }
1710
+ {
1711
+ CustomType<MyType, kConvToStatusOr | kConvToStatus | kConvExplicit> v;
1712
+ absl::StatusOr<MyType> statusor(v);
1713
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1714
+ }
1715
+ {
1716
+ CustomType<MyType,
1717
+ kConvToT | kConvToStatusOr | kConvToStatus | kConvExplicit>
1718
+ v;
1719
+ absl::StatusOr<MyType> statusor(v);
1720
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1721
+ }
1722
+ {
1723
+ CustomType<MyType, kConvToStatusOr> v;
1724
+ absl::StatusOr<MyType> statusor = v;
1725
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1726
+ }
1727
+ {
1728
+ CustomType<MyType, kConvToT | kConvToStatusOr> v;
1729
+ absl::StatusOr<MyType> statusor = v;
1730
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1731
+ }
1732
+ {
1733
+ CustomType<MyType, kConvToStatusOr | kConvToStatus> v;
1734
+ absl::StatusOr<MyType> statusor = v;
1735
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1736
+ }
1737
+ {
1738
+ CustomType<MyType, kConvToT | kConvToStatusOr | kConvToStatus> v;
1739
+ absl::StatusOr<MyType> statusor = v;
1740
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1741
+ }
1742
+ }
1743
+
1744
+ TEST(StatusOr, ConstructionFromTypeConvertibleToStatus) {
1745
+ // Construction fails because conversion to `Status` is explicit.
1746
+ {
1747
+ CustomType<MyType, kConvToStatus | kConvExplicit> v;
1748
+ absl::StatusOr<MyType> statusor(v);
1749
+ EXPECT_FALSE(statusor.ok());
1750
+ EXPECT_EQ(statusor.status(), static_cast<absl::Status>(v));
1751
+ }
1752
+ {
1753
+ CustomType<MyType, kConvToT | kConvToStatus | kConvExplicit> v;
1754
+ absl::StatusOr<MyType> statusor(v);
1755
+ EXPECT_FALSE(statusor.ok());
1756
+ EXPECT_EQ(statusor.status(), static_cast<absl::Status>(v));
1757
+ }
1758
+ {
1759
+ CustomType<MyType, kConvToStatus> v;
1760
+ absl::StatusOr<MyType> statusor = v;
1761
+ EXPECT_FALSE(statusor.ok());
1762
+ EXPECT_EQ(statusor.status(), static_cast<absl::Status>(v));
1763
+ }
1764
+ {
1765
+ CustomType<MyType, kConvToT | kConvToStatus> v;
1766
+ absl::StatusOr<MyType> statusor = v;
1767
+ EXPECT_FALSE(statusor.ok());
1768
+ EXPECT_EQ(statusor.status(), static_cast<absl::Status>(v));
1769
+ }
1770
+ }
1771
+
1772
+ TEST(StatusOr, AssignmentFromT) {
1773
+ // Assign to absl::StatusOr<T> from T when T is convertible to
1774
+ // absl::StatusOr<T>
1775
+ {
1776
+ ConvertibleToAnyStatusOr v;
1777
+ absl::StatusOr<ConvertibleToAnyStatusOr> statusor;
1778
+ statusor = v;
1779
+ EXPECT_TRUE(statusor.ok());
1780
+ }
1781
+ // Assign to absl::StatusOr<T> from T when T is convertible to Status
1782
+ {
1783
+ CustomType<MyType, kConvToStatus> v;
1784
+ absl::StatusOr<CustomType<MyType, kConvToStatus>> statusor;
1785
+ statusor = v;
1786
+ EXPECT_TRUE(statusor.ok());
1787
+ }
1788
+ }
1789
+
1790
+ TEST(StatusOr, AssignmentFromTypeConvertibleToT) {
1791
+ // Assign to absl::StatusOr<T> from U when U is convertible to T
1792
+ {
1793
+ CustomType<MyType, kConvToT> v;
1794
+ absl::StatusOr<MyType> statusor;
1795
+ statusor = v;
1796
+ EXPECT_TRUE(statusor.ok());
1797
+ }
1798
+ }
1799
+
1800
+ TEST(StatusOr, AssignmentFromTypeWithConversionOperatortoStatusOrT) {
1801
+ // Assign to absl::StatusOr<T> from U when U has conversion operator to
1802
+ // absl::StatusOr<T>
1803
+ {
1804
+ CustomType<MyType, kConvToStatusOr> v;
1805
+ absl::StatusOr<MyType> statusor;
1806
+ statusor = v;
1807
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1808
+ }
1809
+ {
1810
+ CustomType<MyType, kConvToT | kConvToStatusOr> v;
1811
+ absl::StatusOr<MyType> statusor;
1812
+ statusor = v;
1813
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1814
+ }
1815
+ {
1816
+ CustomType<MyType, kConvToStatusOr | kConvToStatus> v;
1817
+ absl::StatusOr<MyType> statusor;
1818
+ statusor = v;
1819
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1820
+ }
1821
+ {
1822
+ CustomType<MyType, kConvToT | kConvToStatusOr | kConvToStatus> v;
1823
+ absl::StatusOr<MyType> statusor;
1824
+ statusor = v;
1825
+ EXPECT_EQ(statusor, v.operator absl::StatusOr<MyType>());
1826
+ }
1827
+ }
1828
+
1829
+ TEST(StatusOr, AssignmentFromTypeConvertibleToStatus) {
1830
+ // Assign to absl::StatusOr<T> from U when U is convertible to Status
1831
+ {
1832
+ CustomType<MyType, kConvToStatus> v;
1833
+ absl::StatusOr<MyType> statusor;
1834
+ statusor = v;
1835
+ EXPECT_FALSE(statusor.ok());
1836
+ EXPECT_EQ(statusor.status(), static_cast<absl::Status>(v));
1837
+ }
1838
+ {
1839
+ CustomType<MyType, kConvToT | kConvToStatus> v;
1840
+ absl::StatusOr<MyType> statusor;
1841
+ statusor = v;
1842
+ EXPECT_FALSE(statusor.ok());
1843
+ EXPECT_EQ(statusor.status(), static_cast<absl::Status>(v));
1844
+ }
1845
+ }
1846
+
1847
+ } // namespace