re2 1.22.2 → 1.23.0

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 (495) hide show
  1. package/README.md +60 -4
  2. package/binding.gyp +5 -1
  3. package/lib/addon.cc +4 -0
  4. package/lib/new.cc +1 -246
  5. package/lib/pattern.cc +252 -0
  6. package/lib/pattern.h +10 -0
  7. package/lib/set.cc +777 -0
  8. package/lib/wrapped_re2_set.h +42 -0
  9. package/package.json +21 -9
  10. package/re2.d.ts +46 -9
  11. package/vendor/abseil-cpp/CMake/AbseilDll.cmake +14 -24
  12. package/vendor/abseil-cpp/CMake/AbseilHelpers.cmake +3 -3
  13. package/vendor/abseil-cpp/CMake/README.md +2 -2
  14. package/vendor/abseil-cpp/CMakeLists.txt +3 -3
  15. package/vendor/abseil-cpp/MODULE.bazel +6 -9
  16. package/vendor/abseil-cpp/README.md +6 -8
  17. package/vendor/abseil-cpp/absl/abseil.podspec.gen.py +6 -4
  18. package/vendor/abseil-cpp/absl/algorithm/BUILD.bazel +3 -0
  19. package/vendor/abseil-cpp/absl/algorithm/CMakeLists.txt +1 -0
  20. package/vendor/abseil-cpp/absl/algorithm/container.h +2 -19
  21. package/vendor/abseil-cpp/absl/algorithm/container_test.cc +4 -11
  22. package/vendor/abseil-cpp/absl/base/BUILD.bazel +60 -45
  23. package/vendor/abseil-cpp/absl/base/CMakeLists.txt +57 -38
  24. package/vendor/abseil-cpp/absl/base/attributes.h +76 -7
  25. package/vendor/abseil-cpp/absl/base/attributes_test.cc +43 -0
  26. package/vendor/abseil-cpp/absl/base/call_once.h +11 -12
  27. package/vendor/abseil-cpp/absl/base/config.h +22 -129
  28. package/vendor/abseil-cpp/absl/base/exception_safety_testing_test.cc +0 -4
  29. package/vendor/abseil-cpp/absl/base/{internal/fast_type_id.h → fast_type_id.h} +11 -16
  30. package/vendor/abseil-cpp/absl/base/{internal/fast_type_id_test.cc → fast_type_id_test.cc} +34 -30
  31. package/vendor/abseil-cpp/absl/base/internal/cycleclock.cc +0 -5
  32. package/vendor/abseil-cpp/absl/base/internal/cycleclock_config.h +7 -7
  33. package/vendor/abseil-cpp/absl/base/internal/endian.h +34 -38
  34. package/vendor/abseil-cpp/absl/base/internal/iterator_traits.h +71 -0
  35. package/vendor/abseil-cpp/absl/base/internal/iterator_traits_test.cc +85 -0
  36. package/vendor/abseil-cpp/absl/base/internal/iterator_traits_test_helper.h +97 -0
  37. package/vendor/abseil-cpp/absl/base/internal/low_level_alloc.cc +39 -9
  38. package/vendor/abseil-cpp/absl/base/internal/low_level_alloc.h +6 -0
  39. package/vendor/abseil-cpp/absl/base/internal/poison.cc +7 -6
  40. package/vendor/abseil-cpp/absl/base/internal/spinlock.cc +15 -28
  41. package/vendor/abseil-cpp/absl/base/internal/spinlock.h +65 -35
  42. package/vendor/abseil-cpp/absl/base/internal/spinlock_benchmark.cc +2 -2
  43. package/vendor/abseil-cpp/absl/base/internal/sysinfo_test.cc +2 -2
  44. package/vendor/abseil-cpp/absl/base/internal/thread_identity_benchmark.cc +1 -1
  45. package/vendor/abseil-cpp/absl/base/internal/thread_identity_test.cc +4 -4
  46. package/vendor/abseil-cpp/absl/base/internal/unaligned_access.h +6 -6
  47. package/vendor/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +4 -0
  48. package/vendor/abseil-cpp/absl/base/internal/unscaledcycleclock.h +8 -3
  49. package/vendor/abseil-cpp/absl/base/no_destructor.h +11 -32
  50. package/vendor/abseil-cpp/absl/base/no_destructor_test.cc +0 -4
  51. package/vendor/abseil-cpp/absl/base/nullability.h +83 -72
  52. package/vendor/abseil-cpp/absl/base/nullability_test.cc +25 -64
  53. package/vendor/abseil-cpp/absl/base/options.h +3 -80
  54. package/vendor/abseil-cpp/absl/base/policy_checks.h +7 -7
  55. package/vendor/abseil-cpp/absl/base/raw_logging_test.cc +15 -0
  56. package/vendor/abseil-cpp/absl/base/spinlock_test_common.cc +50 -30
  57. package/vendor/abseil-cpp/absl/cleanup/BUILD.bazel +2 -1
  58. package/vendor/abseil-cpp/absl/cleanup/CMakeLists.txt +0 -1
  59. package/vendor/abseil-cpp/absl/cleanup/cleanup.h +1 -3
  60. package/vendor/abseil-cpp/absl/cleanup/cleanup_test.cc +0 -2
  61. package/vendor/abseil-cpp/absl/cleanup/internal/cleanup.h +3 -4
  62. package/vendor/abseil-cpp/absl/container/BUILD.bazel +74 -1
  63. package/vendor/abseil-cpp/absl/container/CMakeLists.txt +73 -0
  64. package/vendor/abseil-cpp/absl/container/btree_benchmark.cc +51 -9
  65. package/vendor/abseil-cpp/absl/container/btree_map.h +8 -6
  66. package/vendor/abseil-cpp/absl/container/btree_set.h +8 -6
  67. package/vendor/abseil-cpp/absl/container/btree_test.cc +89 -4
  68. package/vendor/abseil-cpp/absl/container/fixed_array.h +7 -15
  69. package/vendor/abseil-cpp/absl/container/fixed_array_test.cc +17 -0
  70. package/vendor/abseil-cpp/absl/container/flat_hash_map.h +20 -15
  71. package/vendor/abseil-cpp/absl/container/flat_hash_map_test.cc +8 -14
  72. package/vendor/abseil-cpp/absl/container/flat_hash_set.h +19 -14
  73. package/vendor/abseil-cpp/absl/container/flat_hash_set_test.cc +46 -0
  74. package/vendor/abseil-cpp/absl/container/inlined_vector.h +7 -6
  75. package/vendor/abseil-cpp/absl/container/inlined_vector_test.cc +28 -0
  76. package/vendor/abseil-cpp/absl/container/internal/btree.h +132 -29
  77. package/vendor/abseil-cpp/absl/container/internal/btree_container.h +175 -71
  78. package/vendor/abseil-cpp/absl/container/internal/common.h +43 -0
  79. package/vendor/abseil-cpp/absl/container/internal/common_policy_traits.h +1 -2
  80. package/vendor/abseil-cpp/absl/container/internal/compressed_tuple.h +28 -24
  81. package/vendor/abseil-cpp/absl/container/internal/compressed_tuple_test.cc +4 -17
  82. package/vendor/abseil-cpp/absl/container/internal/container_memory.h +80 -17
  83. package/vendor/abseil-cpp/absl/container/internal/container_memory_test.cc +32 -2
  84. package/vendor/abseil-cpp/absl/container/internal/hash_function_defaults.h +13 -8
  85. package/vendor/abseil-cpp/absl/container/internal/hash_function_defaults_test.cc +1 -52
  86. package/vendor/abseil-cpp/absl/container/internal/hash_generator_testing.cc +9 -31
  87. package/vendor/abseil-cpp/absl/container/internal/hash_generator_testing.h +23 -32
  88. package/vendor/abseil-cpp/absl/container/internal/hash_policy_testing.h +5 -1
  89. package/vendor/abseil-cpp/absl/container/internal/hash_policy_traits.h +11 -23
  90. package/vendor/abseil-cpp/absl/container/internal/hash_policy_traits_test.cc +14 -9
  91. package/vendor/abseil-cpp/absl/container/internal/hashtable_control_bytes.h +516 -0
  92. package/vendor/abseil-cpp/absl/container/internal/hashtable_control_bytes_test.cc +259 -0
  93. package/vendor/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +23 -6
  94. package/vendor/abseil-cpp/absl/container/internal/hashtablez_sampler.h +32 -13
  95. package/vendor/abseil-cpp/absl/container/internal/hashtablez_sampler_test.cc +8 -8
  96. package/vendor/abseil-cpp/absl/container/internal/inlined_vector.h +2 -7
  97. package/vendor/abseil-cpp/absl/container/internal/layout.h +26 -42
  98. package/vendor/abseil-cpp/absl/container/internal/raw_hash_map.h +199 -68
  99. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set.cc +1506 -213
  100. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set.h +1095 -1658
  101. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_allocator_test.cc +3 -2
  102. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_benchmark.cc +31 -29
  103. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_probe_benchmark.cc +51 -20
  104. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_resize_impl.h +79 -0
  105. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_resize_impl_test.cc +66 -0
  106. package/vendor/abseil-cpp/absl/container/internal/raw_hash_set_test.cc +707 -363
  107. package/vendor/abseil-cpp/absl/container/node_hash_map.h +20 -15
  108. package/vendor/abseil-cpp/absl/container/node_hash_map_test.cc +0 -3
  109. package/vendor/abseil-cpp/absl/container/node_hash_set.h +18 -13
  110. package/vendor/abseil-cpp/absl/container/sample_element_size_test.cc +3 -8
  111. package/vendor/abseil-cpp/absl/copts/AbseilConfigureCopts.cmake +1 -1
  112. package/vendor/abseil-cpp/absl/copts/GENERATED_AbseilCopts.cmake +9 -20
  113. package/vendor/abseil-cpp/absl/copts/GENERATED_copts.bzl +9 -20
  114. package/vendor/abseil-cpp/absl/copts/copts.py +24 -15
  115. package/vendor/abseil-cpp/absl/crc/BUILD.bazel +3 -0
  116. package/vendor/abseil-cpp/absl/crc/crc32c.cc +0 -4
  117. package/vendor/abseil-cpp/absl/crc/crc32c.h +7 -5
  118. package/vendor/abseil-cpp/absl/crc/crc32c_benchmark.cc +17 -4
  119. package/vendor/abseil-cpp/absl/crc/crc32c_test.cc +30 -0
  120. package/vendor/abseil-cpp/absl/crc/internal/cpu_detect.cc +17 -0
  121. package/vendor/abseil-cpp/absl/crc/internal/cpu_detect.h +7 -1
  122. package/vendor/abseil-cpp/absl/crc/internal/crc32_x86_arm_combined_simd.h +0 -22
  123. package/vendor/abseil-cpp/absl/crc/internal/crc_memcpy_x86_arm_combined.cc +5 -0
  124. package/vendor/abseil-cpp/absl/crc/internal/crc_x86_arm_combined.cc +136 -165
  125. package/vendor/abseil-cpp/absl/crc/internal/gen_crc32c_consts.py +90 -0
  126. package/vendor/abseil-cpp/absl/debugging/BUILD.bazel +7 -0
  127. package/vendor/abseil-cpp/absl/debugging/CMakeLists.txt +4 -0
  128. package/vendor/abseil-cpp/absl/debugging/internal/addresses.h +57 -0
  129. package/vendor/abseil-cpp/absl/debugging/internal/decode_rust_punycode.cc +1 -1
  130. package/vendor/abseil-cpp/absl/debugging/internal/decode_rust_punycode.h +5 -5
  131. package/vendor/abseil-cpp/absl/debugging/internal/demangle.cc +8 -35
  132. package/vendor/abseil-cpp/absl/debugging/internal/demangle_rust.cc +16 -16
  133. package/vendor/abseil-cpp/absl/debugging/internal/demangle_test.cc +11 -10
  134. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +40 -37
  135. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +16 -7
  136. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_config.h +6 -5
  137. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_emscripten-inl.inc +14 -5
  138. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +10 -4
  139. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +27 -16
  140. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +13 -4
  141. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +4 -3
  142. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +15 -28
  143. package/vendor/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +25 -14
  144. package/vendor/abseil-cpp/absl/debugging/internal/vdso_support.cc +4 -0
  145. package/vendor/abseil-cpp/absl/debugging/stacktrace.cc +161 -27
  146. package/vendor/abseil-cpp/absl/debugging/stacktrace.h +73 -5
  147. package/vendor/abseil-cpp/absl/debugging/stacktrace_test.cc +435 -1
  148. package/vendor/abseil-cpp/absl/debugging/symbolize_elf.inc +55 -63
  149. package/vendor/abseil-cpp/absl/debugging/symbolize_emscripten.inc +3 -2
  150. package/vendor/abseil-cpp/absl/debugging/symbolize_win32.inc +25 -6
  151. package/vendor/abseil-cpp/absl/flags/BUILD.bazel +6 -0
  152. package/vendor/abseil-cpp/absl/flags/CMakeLists.txt +3 -0
  153. package/vendor/abseil-cpp/absl/flags/commandlineflag.h +2 -2
  154. package/vendor/abseil-cpp/absl/flags/flag.h +4 -3
  155. package/vendor/abseil-cpp/absl/flags/internal/commandlineflag.h +2 -2
  156. package/vendor/abseil-cpp/absl/flags/internal/flag.cc +14 -13
  157. package/vendor/abseil-cpp/absl/flags/internal/flag.h +34 -34
  158. package/vendor/abseil-cpp/absl/flags/internal/program_name.cc +2 -2
  159. package/vendor/abseil-cpp/absl/flags/internal/registry.h +4 -3
  160. package/vendor/abseil-cpp/absl/flags/internal/usage.cc +2 -2
  161. package/vendor/abseil-cpp/absl/flags/parse.cc +10 -6
  162. package/vendor/abseil-cpp/absl/flags/reflection.cc +9 -7
  163. package/vendor/abseil-cpp/absl/flags/usage.cc +2 -2
  164. package/vendor/abseil-cpp/absl/flags/usage_config.cc +2 -2
  165. package/vendor/abseil-cpp/absl/functional/BUILD.bazel +7 -6
  166. package/vendor/abseil-cpp/absl/functional/CMakeLists.txt +2 -4
  167. package/vendor/abseil-cpp/absl/functional/any_invocable.h +15 -15
  168. package/vendor/abseil-cpp/absl/functional/any_invocable_test.cc +10 -42
  169. package/vendor/abseil-cpp/absl/functional/function_ref.h +2 -9
  170. package/vendor/abseil-cpp/absl/functional/function_ref_test.cc +10 -0
  171. package/vendor/abseil-cpp/absl/functional/function_type_benchmark.cc +1 -1
  172. package/vendor/abseil-cpp/absl/functional/internal/any_invocable.h +112 -227
  173. package/vendor/abseil-cpp/absl/functional/internal/front_binder.h +10 -12
  174. package/vendor/abseil-cpp/absl/functional/internal/function_ref.h +2 -5
  175. package/vendor/abseil-cpp/absl/functional/overload.h +0 -20
  176. package/vendor/abseil-cpp/absl/functional/overload_test.cc +1 -7
  177. package/vendor/abseil-cpp/absl/hash/BUILD.bazel +16 -9
  178. package/vendor/abseil-cpp/absl/hash/CMakeLists.txt +6 -9
  179. package/vendor/abseil-cpp/absl/hash/hash.h +18 -0
  180. package/vendor/abseil-cpp/absl/hash/hash_benchmark.cc +3 -0
  181. package/vendor/abseil-cpp/absl/hash/hash_instantiated_test.cc +1 -1
  182. package/vendor/abseil-cpp/absl/hash/hash_test.cc +131 -30
  183. package/vendor/abseil-cpp/absl/hash/hash_testing.h +20 -20
  184. package/vendor/abseil-cpp/absl/hash/internal/hash.cc +129 -17
  185. package/vendor/abseil-cpp/absl/hash/internal/hash.h +326 -362
  186. package/vendor/abseil-cpp/absl/hash/internal/low_level_hash_test.cc +54 -151
  187. package/vendor/abseil-cpp/absl/hash/internal/spy_hash_state.h +14 -2
  188. package/vendor/abseil-cpp/absl/{strings/cord_buffer.cc → hash/internal/weakly_mixed_integer.h} +14 -6
  189. package/vendor/abseil-cpp/absl/log/BUILD.bazel +4 -0
  190. package/vendor/abseil-cpp/absl/log/CMakeLists.txt +7 -0
  191. package/vendor/abseil-cpp/absl/log/check.h +2 -1
  192. package/vendor/abseil-cpp/absl/log/check_test_impl.inc +308 -14
  193. package/vendor/abseil-cpp/absl/log/die_if_null.h +2 -2
  194. package/vendor/abseil-cpp/absl/log/flags_test.cc +7 -0
  195. package/vendor/abseil-cpp/absl/log/globals.h +4 -5
  196. package/vendor/abseil-cpp/absl/log/internal/BUILD.bazel +13 -9
  197. package/vendor/abseil-cpp/absl/log/internal/append_truncated.h +28 -0
  198. package/vendor/abseil-cpp/absl/log/internal/check_op.cc +24 -22
  199. package/vendor/abseil-cpp/absl/log/internal/check_op.h +149 -94
  200. package/vendor/abseil-cpp/absl/log/internal/conditions.cc +5 -3
  201. package/vendor/abseil-cpp/absl/log/internal/conditions.h +7 -2
  202. package/vendor/abseil-cpp/absl/log/internal/fnmatch_test.cc +1 -0
  203. package/vendor/abseil-cpp/absl/log/internal/log_message.cc +85 -43
  204. package/vendor/abseil-cpp/absl/log/internal/log_message.h +84 -59
  205. package/vendor/abseil-cpp/absl/log/internal/log_sink_set.cc +4 -4
  206. package/vendor/abseil-cpp/absl/log/internal/nullstream.h +1 -0
  207. package/vendor/abseil-cpp/absl/log/internal/proto.cc +3 -2
  208. package/vendor/abseil-cpp/absl/log/internal/proto.h +3 -3
  209. package/vendor/abseil-cpp/absl/log/internal/strip.h +4 -12
  210. package/vendor/abseil-cpp/absl/log/internal/structured.h +3 -7
  211. package/vendor/abseil-cpp/absl/log/internal/vlog_config.cc +9 -9
  212. package/vendor/abseil-cpp/absl/log/internal/vlog_config.h +8 -6
  213. package/vendor/abseil-cpp/absl/log/internal/voidify.h +10 -4
  214. package/vendor/abseil-cpp/absl/log/log.h +48 -35
  215. package/vendor/abseil-cpp/absl/log/log_basic_test_impl.inc +45 -0
  216. package/vendor/abseil-cpp/absl/log/log_entry.cc +241 -19
  217. package/vendor/abseil-cpp/absl/log/log_entry.h +2 -0
  218. package/vendor/abseil-cpp/absl/log/log_format_test.cc +412 -6
  219. package/vendor/abseil-cpp/absl/log/log_modifier_methods_test.cc +20 -0
  220. package/vendor/abseil-cpp/absl/log/log_sink_registry.h +2 -2
  221. package/vendor/abseil-cpp/absl/log/log_streamer_test.cc +15 -2
  222. package/vendor/abseil-cpp/absl/log/scoped_mock_log.h +7 -1
  223. package/vendor/abseil-cpp/absl/log/structured_test.cc +1 -0
  224. package/vendor/abseil-cpp/absl/memory/BUILD.bazel +2 -0
  225. package/vendor/abseil-cpp/absl/meta/BUILD.bazel +2 -0
  226. package/vendor/abseil-cpp/absl/meta/type_traits.h +46 -175
  227. package/vendor/abseil-cpp/absl/meta/type_traits_test.cc +1 -478
  228. package/vendor/abseil-cpp/absl/numeric/BUILD.bazel +7 -3
  229. package/vendor/abseil-cpp/absl/numeric/CMakeLists.txt +2 -0
  230. package/vendor/abseil-cpp/absl/numeric/bits.h +68 -2
  231. package/vendor/abseil-cpp/absl/numeric/bits_benchmark.cc +1 -1
  232. package/vendor/abseil-cpp/absl/numeric/bits_test.cc +83 -0
  233. package/vendor/abseil-cpp/absl/numeric/int128.cc +0 -52
  234. package/vendor/abseil-cpp/absl/numeric/int128_benchmark.cc +14 -15
  235. package/vendor/abseil-cpp/absl/numeric/int128_test.cc +13 -8
  236. package/vendor/abseil-cpp/absl/numeric/internal/bits.h +39 -7
  237. package/vendor/abseil-cpp/absl/profiling/BUILD.bazel +47 -0
  238. package/vendor/abseil-cpp/absl/profiling/CMakeLists.txt +38 -0
  239. package/vendor/abseil-cpp/absl/profiling/hashtable.cc +124 -0
  240. package/vendor/abseil-cpp/absl/profiling/hashtable.h +40 -0
  241. package/vendor/abseil-cpp/absl/profiling/internal/exponential_biased.cc +1 -1
  242. package/vendor/abseil-cpp/absl/profiling/internal/profile_builder.cc +462 -0
  243. package/vendor/abseil-cpp/absl/profiling/internal/profile_builder.h +138 -0
  244. package/vendor/abseil-cpp/absl/profiling/internal/sample_recorder.h +9 -9
  245. package/vendor/abseil-cpp/absl/profiling/internal/sample_recorder_test.cc +7 -3
  246. package/vendor/abseil-cpp/absl/random/BUILD.bazel +6 -4
  247. package/vendor/abseil-cpp/absl/random/CMakeLists.txt +20 -19
  248. package/vendor/abseil-cpp/absl/random/benchmarks.cc +16 -23
  249. package/vendor/abseil-cpp/absl/random/bit_gen_ref.h +10 -11
  250. package/vendor/abseil-cpp/absl/random/bit_gen_ref_test.cc +7 -2
  251. package/vendor/abseil-cpp/absl/random/distributions.h +6 -8
  252. package/vendor/abseil-cpp/absl/random/gaussian_distribution.h +1 -1
  253. package/vendor/abseil-cpp/absl/random/internal/BUILD.bazel +19 -20
  254. package/vendor/abseil-cpp/absl/random/internal/distribution_caller.h +5 -6
  255. package/vendor/abseil-cpp/absl/random/internal/{pool_urbg.cc → entropy_pool.cc} +24 -92
  256. package/vendor/abseil-cpp/absl/{base/inline_variable_test_b.cc → random/internal/entropy_pool.h} +14 -6
  257. package/vendor/abseil-cpp/absl/random/internal/entropy_pool_test.cc +119 -0
  258. package/vendor/abseil-cpp/absl/random/internal/mock_helpers.h +6 -7
  259. package/vendor/abseil-cpp/absl/random/internal/nonsecure_base.h +5 -6
  260. package/vendor/abseil-cpp/absl/random/internal/nonsecure_base_test.cc +39 -0
  261. package/vendor/abseil-cpp/absl/random/internal/randen_benchmarks.cc +8 -6
  262. package/vendor/abseil-cpp/absl/random/internal/randen_detect.cc +1 -1
  263. package/vendor/abseil-cpp/absl/random/internal/seed_material.cc +20 -12
  264. package/vendor/abseil-cpp/absl/random/internal/seed_material.h +5 -5
  265. package/vendor/abseil-cpp/absl/random/internal/seed_material_test.cc +3 -0
  266. package/vendor/abseil-cpp/absl/random/mock_distributions_test.cc +5 -4
  267. package/vendor/abseil-cpp/absl/random/mocking_bit_gen.h +8 -10
  268. package/vendor/abseil-cpp/absl/random/random.h +88 -53
  269. package/vendor/abseil-cpp/absl/random/seed_sequences.cc +6 -2
  270. package/vendor/abseil-cpp/absl/status/BUILD.bazel +26 -0
  271. package/vendor/abseil-cpp/absl/status/internal/status_internal.cc +3 -4
  272. package/vendor/abseil-cpp/absl/status/internal/status_internal.h +3 -4
  273. package/vendor/abseil-cpp/absl/status/internal/status_matchers.cc +4 -3
  274. package/vendor/abseil-cpp/absl/status/internal/statusor_internal.h +194 -32
  275. package/vendor/abseil-cpp/absl/status/status.cc +4 -8
  276. package/vendor/abseil-cpp/absl/status/status.h +8 -8
  277. package/vendor/abseil-cpp/absl/{base/inline_variable_test_a.cc → status/status_benchmark.cc} +20 -10
  278. package/vendor/abseil-cpp/absl/status/status_matchers_test.cc +65 -0
  279. package/vendor/abseil-cpp/absl/status/status_payload_printer.h +2 -2
  280. package/vendor/abseil-cpp/absl/status/statusor.cc +2 -2
  281. package/vendor/abseil-cpp/absl/status/statusor.h +49 -102
  282. package/vendor/abseil-cpp/absl/status/statusor_benchmark.cc +480 -0
  283. package/vendor/abseil-cpp/absl/status/statusor_test.cc +323 -1
  284. package/vendor/abseil-cpp/absl/strings/BUILD.bazel +70 -34
  285. package/vendor/abseil-cpp/absl/strings/CMakeLists.txt +6 -3
  286. package/vendor/abseil-cpp/absl/strings/ascii.cc +9 -9
  287. package/vendor/abseil-cpp/absl/strings/ascii.h +18 -18
  288. package/vendor/abseil-cpp/absl/strings/ascii_benchmark.cc +5 -8
  289. package/vendor/abseil-cpp/absl/strings/charconv.cc +21 -22
  290. package/vendor/abseil-cpp/absl/strings/charconv.h +5 -5
  291. package/vendor/abseil-cpp/absl/strings/charconv_benchmark.cc +1 -2
  292. package/vendor/abseil-cpp/absl/strings/charset_benchmark.cc +1 -1
  293. package/vendor/abseil-cpp/absl/strings/cord.cc +54 -58
  294. package/vendor/abseil-cpp/absl/strings/cord.h +94 -84
  295. package/vendor/abseil-cpp/absl/strings/cord_analysis.cc +11 -11
  296. package/vendor/abseil-cpp/absl/strings/cord_analysis.h +3 -3
  297. package/vendor/abseil-cpp/absl/strings/cord_test.cc +23 -0
  298. package/vendor/abseil-cpp/absl/strings/cordz_test_helpers.h +4 -5
  299. package/vendor/abseil-cpp/absl/strings/escaping.cc +130 -149
  300. package/vendor/abseil-cpp/absl/strings/escaping.h +9 -10
  301. package/vendor/abseil-cpp/absl/strings/escaping_benchmark.cc +2 -3
  302. package/vendor/abseil-cpp/absl/strings/escaping_test.cc +19 -9
  303. package/vendor/abseil-cpp/absl/strings/internal/charconv_bigint.cc +1 -1
  304. package/vendor/abseil-cpp/absl/strings/internal/charconv_bigint_test.cc +1 -1
  305. package/vendor/abseil-cpp/absl/strings/internal/cord_internal.h +6 -10
  306. package/vendor/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +0 -4
  307. package/vendor/abseil-cpp/absl/strings/internal/cordz_handle.cc +6 -6
  308. package/vendor/abseil-cpp/absl/strings/internal/cordz_info.cc +5 -9
  309. package/vendor/abseil-cpp/absl/strings/internal/cordz_info.h +2 -4
  310. package/vendor/abseil-cpp/absl/strings/internal/damerau_levenshtein_distance_benchmark.cc +56 -0
  311. package/vendor/abseil-cpp/absl/strings/internal/memutil_benchmark.cc +2 -3
  312. package/vendor/abseil-cpp/absl/strings/internal/ostringstream_benchmark.cc +1 -2
  313. package/vendor/abseil-cpp/absl/strings/internal/str_format/arg.cc +7 -63
  314. package/vendor/abseil-cpp/absl/strings/internal/str_format/arg.h +1 -11
  315. package/vendor/abseil-cpp/absl/strings/internal/str_format/convert_test.cc +1 -6
  316. package/vendor/abseil-cpp/absl/strings/internal/str_format/extension.cc +0 -22
  317. package/vendor/abseil-cpp/absl/strings/internal/str_format/extension_test.cc +3 -2
  318. package/vendor/abseil-cpp/absl/strings/internal/str_format/output.cc +5 -3
  319. package/vendor/abseil-cpp/absl/strings/internal/str_format/parser.h +4 -2
  320. package/vendor/abseil-cpp/absl/strings/internal/str_join_internal.h +3 -3
  321. package/vendor/abseil-cpp/absl/strings/internal/str_split_internal.h +7 -2
  322. package/vendor/abseil-cpp/absl/strings/internal/string_constant.h +0 -5
  323. package/vendor/abseil-cpp/absl/strings/internal/utf8.cc +96 -1
  324. package/vendor/abseil-cpp/absl/strings/internal/utf8.h +15 -1
  325. package/vendor/abseil-cpp/absl/strings/internal/utf8_test.cc +196 -3
  326. package/vendor/abseil-cpp/absl/strings/numbers.cc +53 -32
  327. package/vendor/abseil-cpp/absl/strings/numbers.h +87 -58
  328. package/vendor/abseil-cpp/absl/strings/numbers_benchmark.cc +1 -1
  329. package/vendor/abseil-cpp/absl/strings/numbers_test.cc +634 -120
  330. package/vendor/abseil-cpp/absl/strings/str_cat.cc +6 -7
  331. package/vendor/abseil-cpp/absl/strings/str_cat.h +32 -32
  332. package/vendor/abseil-cpp/absl/strings/str_cat_benchmark.cc +25 -1
  333. package/vendor/abseil-cpp/absl/strings/str_cat_test.cc +2 -7
  334. package/vendor/abseil-cpp/absl/strings/str_format.h +18 -18
  335. package/vendor/abseil-cpp/absl/strings/str_format_test.cc +8 -14
  336. package/vendor/abseil-cpp/absl/strings/str_join_benchmark.cc +2 -3
  337. package/vendor/abseil-cpp/absl/strings/str_replace.cc +3 -3
  338. package/vendor/abseil-cpp/absl/strings/str_replace.h +6 -6
  339. package/vendor/abseil-cpp/absl/strings/str_replace_benchmark.cc +2 -3
  340. package/vendor/abseil-cpp/absl/strings/str_split.h +2 -2
  341. package/vendor/abseil-cpp/absl/strings/str_split_benchmark.cc +2 -3
  342. package/vendor/abseil-cpp/absl/strings/string_view.cc +4 -9
  343. package/vendor/abseil-cpp/absl/strings/string_view.h +38 -39
  344. package/vendor/abseil-cpp/absl/strings/string_view_benchmark.cc +4 -6
  345. package/vendor/abseil-cpp/absl/strings/string_view_test.cc +2 -50
  346. package/vendor/abseil-cpp/absl/strings/strip.h +4 -4
  347. package/vendor/abseil-cpp/absl/strings/substitute.cc +5 -4
  348. package/vendor/abseil-cpp/absl/strings/substitute.h +66 -64
  349. package/vendor/abseil-cpp/absl/strings/substitute_benchmark.cc +158 -0
  350. package/vendor/abseil-cpp/absl/synchronization/BUILD.bazel +6 -1
  351. package/vendor/abseil-cpp/absl/synchronization/CMakeLists.txt +2 -1
  352. package/vendor/abseil-cpp/absl/synchronization/barrier.cc +1 -1
  353. package/vendor/abseil-cpp/absl/synchronization/barrier_test.cc +3 -3
  354. package/vendor/abseil-cpp/absl/synchronization/blocking_counter.cc +2 -2
  355. package/vendor/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +3 -3
  356. package/vendor/abseil-cpp/absl/synchronization/internal/futex_waiter.cc +0 -4
  357. package/vendor/abseil-cpp/absl/synchronization/internal/graphcycles.cc +30 -33
  358. package/vendor/abseil-cpp/absl/synchronization/internal/graphcycles_benchmark.cc +2 -3
  359. package/vendor/abseil-cpp/absl/synchronization/internal/graphcycles_test.cc +6 -5
  360. package/vendor/abseil-cpp/absl/synchronization/internal/kernel_timeout.cc +0 -5
  361. package/vendor/abseil-cpp/absl/synchronization/internal/pthread_waiter.cc +0 -4
  362. package/vendor/abseil-cpp/absl/synchronization/internal/sem_waiter.cc +0 -4
  363. package/vendor/abseil-cpp/absl/synchronization/internal/stdcpp_waiter.cc +0 -4
  364. package/vendor/abseil-cpp/absl/synchronization/internal/thread_pool.h +3 -3
  365. package/vendor/abseil-cpp/absl/synchronization/internal/waiter_base.cc +0 -4
  366. package/vendor/abseil-cpp/absl/synchronization/internal/waiter_test.cc +12 -3
  367. package/vendor/abseil-cpp/absl/synchronization/internal/win32_waiter.cc +0 -4
  368. package/vendor/abseil-cpp/absl/synchronization/lifetime_test.cc +4 -4
  369. package/vendor/abseil-cpp/absl/synchronization/mutex.cc +27 -29
  370. package/vendor/abseil-cpp/absl/synchronization/mutex.h +205 -126
  371. package/vendor/abseil-cpp/absl/synchronization/mutex_benchmark.cc +13 -31
  372. package/vendor/abseil-cpp/absl/synchronization/mutex_test.cc +183 -169
  373. package/vendor/abseil-cpp/absl/synchronization/notification.cc +5 -5
  374. package/vendor/abseil-cpp/absl/synchronization/notification.h +1 -1
  375. package/vendor/abseil-cpp/absl/synchronization/notification_test.cc +3 -3
  376. package/vendor/abseil-cpp/absl/time/BUILD.bazel +9 -1
  377. package/vendor/abseil-cpp/absl/time/CMakeLists.txt +3 -1
  378. package/vendor/abseil-cpp/absl/time/civil_time.cc +1 -0
  379. package/vendor/abseil-cpp/absl/time/civil_time_test.cc +134 -0
  380. package/vendor/abseil-cpp/absl/time/clock.cc +11 -14
  381. package/vendor/abseil-cpp/absl/time/duration.cc +14 -9
  382. package/vendor/abseil-cpp/absl/time/duration_test.cc +6 -7
  383. package/vendor/abseil-cpp/absl/time/internal/cctz/BUILD.bazel +14 -3
  384. package/vendor/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +12 -0
  385. package/vendor/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +1 -1
  386. package/vendor/abseil-cpp/absl/time/internal/cctz/src/cctz_benchmark.cc +4 -490
  387. package/vendor/abseil-cpp/absl/time/internal/cctz/src/test_time_zone_names.cc +515 -0
  388. package/vendor/abseil-cpp/absl/time/internal/cctz/src/test_time_zone_names.h +33 -0
  389. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +41 -4
  390. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_format_test.cc +22 -23
  391. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +90 -111
  392. package/vendor/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup_test.cc +1 -488
  393. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/version +1 -1
  394. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/America/Coyhaique +0 -0
  395. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Asia/Tehran +0 -0
  396. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/Iran +0 -0
  397. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/zone1970.tab +2 -1
  398. package/vendor/abseil-cpp/absl/time/internal/cctz/testdata/zoneinfo/zonenow.tab +1 -1
  399. package/vendor/abseil-cpp/absl/time/time.h +24 -18
  400. package/vendor/abseil-cpp/absl/time/time_test.cc +26 -0
  401. package/vendor/abseil-cpp/absl/types/BUILD.bazel +11 -164
  402. package/vendor/abseil-cpp/absl/types/CMakeLists.txt +23 -167
  403. package/vendor/abseil-cpp/absl/types/any.h +9 -484
  404. package/vendor/abseil-cpp/absl/types/optional.h +7 -747
  405. package/vendor/abseil-cpp/absl/types/span.h +46 -19
  406. package/vendor/abseil-cpp/absl/types/span_test.cc +27 -0
  407. package/vendor/abseil-cpp/absl/types/variant.h +5 -784
  408. package/vendor/abseil-cpp/absl/types/variant_test.cc +43 -2597
  409. package/vendor/abseil-cpp/absl/utility/BUILD.bazel +1 -41
  410. package/vendor/abseil-cpp/absl/utility/CMakeLists.txt +0 -40
  411. package/vendor/abseil-cpp/absl/utility/utility.h +10 -185
  412. package/vendor/abseil-cpp/ci/absl_alternate_options.h +2 -3
  413. package/vendor/abseil-cpp/ci/cmake_common.sh +2 -2
  414. package/vendor/abseil-cpp/ci/linux_arm_clang-latest_libcxx_bazel.sh +12 -13
  415. package/vendor/abseil-cpp/ci/linux_clang-latest_libcxx_asan_bazel.sh +24 -21
  416. package/vendor/abseil-cpp/ci/linux_clang-latest_libcxx_bazel.sh +12 -12
  417. package/vendor/abseil-cpp/ci/linux_clang-latest_libcxx_tsan_bazel.sh +23 -22
  418. package/vendor/abseil-cpp/ci/linux_clang-latest_libstdcxx_bazel.sh +20 -19
  419. package/vendor/abseil-cpp/ci/linux_docker_containers.sh +4 -4
  420. package/vendor/abseil-cpp/ci/linux_gcc-floor_libstdcxx_bazel.sh +17 -17
  421. package/vendor/abseil-cpp/ci/linux_gcc-latest_libstdcxx_bazel.sh +10 -10
  422. package/vendor/abseil-cpp/ci/linux_gcc-latest_libstdcxx_cmake.sh +1 -1
  423. package/vendor/abseil-cpp/ci/linux_gcc_alpine_cmake.sh +1 -1
  424. package/vendor/abseil-cpp/ci/macos_xcode_bazel.sh +9 -10
  425. package/vendor/abseil-cpp/ci/macos_xcode_cmake.sh +9 -1
  426. package/vendor/abseil-cpp/ci/windows_clangcl_bazel.bat +14 -6
  427. package/vendor/abseil-cpp/ci/windows_msvc_bazel.bat +14 -6
  428. package/vendor/abseil-cpp/ci/windows_msvc_cmake.bat +1 -1
  429. package/vendor/re2/.bazelrc +4 -4
  430. package/vendor/re2/.bcr/metadata.template.json +16 -0
  431. package/vendor/re2/.bcr/presubmit.yml +57 -0
  432. package/vendor/re2/.bcr/source.template.json +5 -0
  433. package/vendor/re2/.github/bazel.sh +1 -7
  434. package/vendor/re2/.github/workflows/ci-bazel.yml +5 -5
  435. package/vendor/re2/.github/workflows/ci-cmake.yml +4 -4
  436. package/vendor/re2/.github/workflows/ci.yml +5 -6
  437. package/vendor/re2/.github/workflows/pages.yml +3 -3
  438. package/vendor/re2/.github/workflows/python.yml +29 -24
  439. package/vendor/re2/.github/workflows/release-bazel.yml +42 -0
  440. package/vendor/re2/.github/workflows/release.yml +15 -4
  441. package/vendor/re2/BUILD.bazel +25 -0
  442. package/vendor/re2/CMakeLists.txt +100 -85
  443. package/vendor/re2/CONTRIBUTING.md +0 -1
  444. package/vendor/re2/MODULE.bazel +10 -10
  445. package/vendor/re2/Makefile +1 -1
  446. package/vendor/re2/README.md +259 -0
  447. package/vendor/re2/python/BUILD.bazel +8 -0
  448. package/vendor/re2/python/re2.py +1 -1
  449. package/vendor/re2/python/re2_test.py +6 -0
  450. package/vendor/re2/python/setup.py +3 -3
  451. package/vendor/re2/re2/bitmap256.cc +3 -4
  452. package/vendor/re2/re2/bitstate.cc +15 -10
  453. package/vendor/re2/re2/dfa.cc +1 -2
  454. package/vendor/re2/re2/parse.cc +3 -4
  455. package/vendor/re2/re2/prog.cc +1 -2
  456. package/vendor/re2/re2/prog.h +1 -0
  457. package/vendor/re2/re2/re2.cc +5 -0
  458. package/vendor/re2/re2/re2.h +9 -9
  459. package/vendor/re2/re2/set.cc +6 -0
  460. package/vendor/re2/re2/set.h +5 -0
  461. package/vendor/re2/re2/testing/re2_arg_test.cc +3 -3
  462. package/vendor/re2/re2/testing/re2_test.cc +8 -0
  463. package/vendor/re2/re2/testing/set_test.cc +5 -0
  464. package/vendor/re2/re2/walker-inl.h +1 -1
  465. package/vendor/abseil-cpp/WORKSPACE +0 -76
  466. package/vendor/abseil-cpp/WORKSPACE.bzlmod +0 -19
  467. package/vendor/abseil-cpp/absl/base/inline_variable_test.cc +0 -64
  468. package/vendor/abseil-cpp/absl/base/internal/inline_variable.h +0 -108
  469. package/vendor/abseil-cpp/absl/base/internal/inline_variable_testing.h +0 -46
  470. package/vendor/abseil-cpp/absl/base/internal/invoke.h +0 -241
  471. package/vendor/abseil-cpp/absl/base/internal/nullability_impl.h +0 -69
  472. package/vendor/abseil-cpp/absl/base/invoke_test.cc +0 -331
  473. package/vendor/abseil-cpp/absl/hash/internal/low_level_hash.cc +0 -148
  474. package/vendor/abseil-cpp/absl/hash/internal/low_level_hash.h +0 -54
  475. package/vendor/abseil-cpp/absl/random/internal/pool_urbg.h +0 -131
  476. package/vendor/abseil-cpp/absl/random/internal/pool_urbg_test.cc +0 -182
  477. package/vendor/abseil-cpp/absl/types/any_exception_safety_test.cc +0 -173
  478. package/vendor/abseil-cpp/absl/types/any_test.cc +0 -778
  479. package/vendor/abseil-cpp/absl/types/bad_any_cast.cc +0 -64
  480. package/vendor/abseil-cpp/absl/types/bad_any_cast.h +0 -75
  481. package/vendor/abseil-cpp/absl/types/bad_optional_access.cc +0 -66
  482. package/vendor/abseil-cpp/absl/types/bad_optional_access.h +0 -78
  483. package/vendor/abseil-cpp/absl/types/bad_variant_access.cc +0 -82
  484. package/vendor/abseil-cpp/absl/types/bad_variant_access.h +0 -82
  485. package/vendor/abseil-cpp/absl/types/internal/optional.h +0 -352
  486. package/vendor/abseil-cpp/absl/types/internal/variant.h +0 -1622
  487. package/vendor/abseil-cpp/absl/types/optional_exception_safety_test.cc +0 -292
  488. package/vendor/abseil-cpp/absl/types/optional_test.cc +0 -1615
  489. package/vendor/abseil-cpp/absl/types/variant_benchmark.cc +0 -222
  490. package/vendor/abseil-cpp/absl/types/variant_exception_safety_test.cc +0 -532
  491. package/vendor/abseil-cpp/absl/utility/internal/if_constexpr.h +0 -70
  492. package/vendor/abseil-cpp/absl/utility/internal/if_constexpr_test.cc +0 -79
  493. package/vendor/abseil-cpp/absl/utility/utility_test.cc +0 -239
  494. package/vendor/re2/.github/workflows/pr.yml +0 -34
  495. package/vendor/re2/README +0 -47
@@ -1,778 +0,0 @@
1
- // Copyright 2017 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/types/any.h"
16
-
17
- // This test is a no-op when absl::any is an alias for std::any.
18
- #if !defined(ABSL_USES_STD_ANY)
19
-
20
- #include <initializer_list>
21
- #include <type_traits>
22
- #include <utility>
23
- #include <vector>
24
-
25
- #include "gtest/gtest.h"
26
- #include "absl/base/config.h"
27
- #include "absl/base/internal/exception_testing.h"
28
- #include "absl/container/internal/test_instance_tracker.h"
29
- #include "absl/log/log.h"
30
-
31
- namespace {
32
- using absl::test_internal::CopyableOnlyInstance;
33
- using absl::test_internal::InstanceTracker;
34
-
35
- template <typename T>
36
- const T& AsConst(const T& t) {
37
- return t;
38
- }
39
-
40
- struct MoveOnly {
41
- MoveOnly() = default;
42
- explicit MoveOnly(int value) : value(value) {}
43
- MoveOnly(MoveOnly&&) = default;
44
- MoveOnly& operator=(MoveOnly&&) = default;
45
-
46
- int value = 0;
47
- };
48
-
49
- struct CopyOnly {
50
- CopyOnly() = default;
51
- explicit CopyOnly(int value) : value(value) {}
52
- CopyOnly(CopyOnly&&) = delete;
53
- CopyOnly& operator=(CopyOnly&&) = delete;
54
- CopyOnly(const CopyOnly&) = default;
55
- CopyOnly& operator=(const CopyOnly&) = default;
56
-
57
- int value = 0;
58
- };
59
-
60
- struct MoveOnlyWithListConstructor {
61
- MoveOnlyWithListConstructor() = default;
62
- explicit MoveOnlyWithListConstructor(std::initializer_list<int> /*ilist*/,
63
- int value)
64
- : value(value) {}
65
- MoveOnlyWithListConstructor(MoveOnlyWithListConstructor&&) = default;
66
- MoveOnlyWithListConstructor& operator=(MoveOnlyWithListConstructor&&) =
67
- default;
68
-
69
- int value = 0;
70
- };
71
-
72
- struct IntMoveOnlyCopyOnly {
73
- IntMoveOnlyCopyOnly(int value, MoveOnly /*move_only*/, CopyOnly /*copy_only*/)
74
- : value(value) {}
75
-
76
- int value;
77
- };
78
-
79
- struct ListMoveOnlyCopyOnly {
80
- ListMoveOnlyCopyOnly(std::initializer_list<int> ilist, MoveOnly /*move_only*/,
81
- CopyOnly /*copy_only*/)
82
- : values(ilist) {}
83
-
84
- std::vector<int> values;
85
- };
86
-
87
- using FunctionType = void();
88
- void FunctionToEmplace() {}
89
-
90
- using ArrayType = int[2];
91
- using DecayedArray = absl::decay_t<ArrayType>;
92
-
93
- TEST(AnyTest, Noexcept) {
94
- static_assert(std::is_nothrow_default_constructible<absl::any>(), "");
95
- static_assert(std::is_nothrow_move_constructible<absl::any>(), "");
96
- static_assert(std::is_nothrow_move_assignable<absl::any>(), "");
97
- static_assert(noexcept(std::declval<absl::any&>().has_value()), "");
98
- static_assert(noexcept(std::declval<absl::any&>().type()), "");
99
- static_assert(noexcept(absl::any_cast<int>(std::declval<absl::any*>())), "");
100
- static_assert(
101
- noexcept(std::declval<absl::any&>().swap(std::declval<absl::any&>())),
102
- "");
103
-
104
- using std::swap;
105
- static_assert(
106
- noexcept(swap(std::declval<absl::any&>(), std::declval<absl::any&>())),
107
- "");
108
- }
109
-
110
- TEST(AnyTest, HasValue) {
111
- absl::any o;
112
- EXPECT_FALSE(o.has_value());
113
- o.emplace<int>();
114
- EXPECT_TRUE(o.has_value());
115
- o.reset();
116
- EXPECT_FALSE(o.has_value());
117
- }
118
-
119
- TEST(AnyTest, Type) {
120
- absl::any o;
121
- EXPECT_EQ(typeid(void), o.type());
122
- o.emplace<int>(5);
123
- EXPECT_EQ(typeid(int), o.type());
124
- o.emplace<float>(5.f);
125
- EXPECT_EQ(typeid(float), o.type());
126
- o.reset();
127
- EXPECT_EQ(typeid(void), o.type());
128
- }
129
-
130
- TEST(AnyTest, EmptyPointerCast) {
131
- // pointer-to-unqualified overload
132
- {
133
- absl::any o;
134
- EXPECT_EQ(nullptr, absl::any_cast<int>(&o));
135
- o.emplace<int>();
136
- EXPECT_NE(nullptr, absl::any_cast<int>(&o));
137
- o.reset();
138
- EXPECT_EQ(nullptr, absl::any_cast<int>(&o));
139
- }
140
-
141
- // pointer-to-const overload
142
- {
143
- absl::any o;
144
- EXPECT_EQ(nullptr, absl::any_cast<int>(&AsConst(o)));
145
- o.emplace<int>();
146
- EXPECT_NE(nullptr, absl::any_cast<int>(&AsConst(o)));
147
- o.reset();
148
- EXPECT_EQ(nullptr, absl::any_cast<int>(&AsConst(o)));
149
- }
150
- }
151
-
152
- TEST(AnyTest, InPlaceConstruction) {
153
- const CopyOnly copy_only{};
154
- absl::any o(absl::in_place_type_t<IntMoveOnlyCopyOnly>(), 5, MoveOnly(),
155
- copy_only);
156
- IntMoveOnlyCopyOnly& v = absl::any_cast<IntMoveOnlyCopyOnly&>(o);
157
- EXPECT_EQ(5, v.value);
158
- }
159
-
160
- TEST(AnyTest, InPlaceConstructionVariableTemplate) {
161
- const CopyOnly copy_only{};
162
- absl::any o(absl::in_place_type<IntMoveOnlyCopyOnly>, 5, MoveOnly(),
163
- copy_only);
164
- auto& v = absl::any_cast<IntMoveOnlyCopyOnly&>(o);
165
- EXPECT_EQ(5, v.value);
166
- }
167
-
168
- TEST(AnyTest, InPlaceConstructionWithCV) {
169
- const CopyOnly copy_only{};
170
- absl::any o(absl::in_place_type_t<const volatile IntMoveOnlyCopyOnly>(), 5,
171
- MoveOnly(), copy_only);
172
- IntMoveOnlyCopyOnly& v = absl::any_cast<IntMoveOnlyCopyOnly&>(o);
173
- EXPECT_EQ(5, v.value);
174
- }
175
-
176
- TEST(AnyTest, InPlaceConstructionWithCVVariableTemplate) {
177
- const CopyOnly copy_only{};
178
- absl::any o(absl::in_place_type<const volatile IntMoveOnlyCopyOnly>, 5,
179
- MoveOnly(), copy_only);
180
- auto& v = absl::any_cast<IntMoveOnlyCopyOnly&>(o);
181
- EXPECT_EQ(5, v.value);
182
- }
183
-
184
- TEST(AnyTest, InPlaceConstructionWithFunction) {
185
- absl::any o(absl::in_place_type_t<FunctionType>(), FunctionToEmplace);
186
- FunctionType*& construction_result = absl::any_cast<FunctionType*&>(o);
187
- EXPECT_EQ(&FunctionToEmplace, construction_result);
188
- }
189
-
190
- TEST(AnyTest, InPlaceConstructionWithFunctionVariableTemplate) {
191
- absl::any o(absl::in_place_type<FunctionType>, FunctionToEmplace);
192
- auto& construction_result = absl::any_cast<FunctionType*&>(o);
193
- EXPECT_EQ(&FunctionToEmplace, construction_result);
194
- }
195
-
196
- TEST(AnyTest, InPlaceConstructionWithArray) {
197
- ArrayType ar = {5, 42};
198
- absl::any o(absl::in_place_type_t<ArrayType>(), ar);
199
- DecayedArray& construction_result = absl::any_cast<DecayedArray&>(o);
200
- EXPECT_EQ(&ar[0], construction_result);
201
- }
202
-
203
- TEST(AnyTest, InPlaceConstructionWithArrayVariableTemplate) {
204
- ArrayType ar = {5, 42};
205
- absl::any o(absl::in_place_type<ArrayType>, ar);
206
- auto& construction_result = absl::any_cast<DecayedArray&>(o);
207
- EXPECT_EQ(&ar[0], construction_result);
208
- }
209
-
210
- TEST(AnyTest, InPlaceConstructionIlist) {
211
- const CopyOnly copy_only{};
212
- absl::any o(absl::in_place_type_t<ListMoveOnlyCopyOnly>(), {1, 2, 3, 4},
213
- MoveOnly(), copy_only);
214
- ListMoveOnlyCopyOnly& v = absl::any_cast<ListMoveOnlyCopyOnly&>(o);
215
- std::vector<int> expected_values = {1, 2, 3, 4};
216
- EXPECT_EQ(expected_values, v.values);
217
- }
218
-
219
- TEST(AnyTest, InPlaceConstructionIlistVariableTemplate) {
220
- const CopyOnly copy_only{};
221
- absl::any o(absl::in_place_type<ListMoveOnlyCopyOnly>, {1, 2, 3, 4},
222
- MoveOnly(), copy_only);
223
- auto& v = absl::any_cast<ListMoveOnlyCopyOnly&>(o);
224
- std::vector<int> expected_values = {1, 2, 3, 4};
225
- EXPECT_EQ(expected_values, v.values);
226
- }
227
-
228
- TEST(AnyTest, InPlaceConstructionIlistWithCV) {
229
- const CopyOnly copy_only{};
230
- absl::any o(absl::in_place_type_t<const volatile ListMoveOnlyCopyOnly>(),
231
- {1, 2, 3, 4}, MoveOnly(), copy_only);
232
- ListMoveOnlyCopyOnly& v = absl::any_cast<ListMoveOnlyCopyOnly&>(o);
233
- std::vector<int> expected_values = {1, 2, 3, 4};
234
- EXPECT_EQ(expected_values, v.values);
235
- }
236
-
237
- TEST(AnyTest, InPlaceConstructionIlistWithCVVariableTemplate) {
238
- const CopyOnly copy_only{};
239
- absl::any o(absl::in_place_type<const volatile ListMoveOnlyCopyOnly>,
240
- {1, 2, 3, 4}, MoveOnly(), copy_only);
241
- auto& v = absl::any_cast<ListMoveOnlyCopyOnly&>(o);
242
- std::vector<int> expected_values = {1, 2, 3, 4};
243
- EXPECT_EQ(expected_values, v.values);
244
- }
245
-
246
- TEST(AnyTest, InPlaceNoArgs) {
247
- absl::any o(absl::in_place_type_t<int>{});
248
- EXPECT_EQ(0, absl::any_cast<int&>(o));
249
- }
250
-
251
- TEST(AnyTest, InPlaceNoArgsVariableTemplate) {
252
- absl::any o(absl::in_place_type<int>);
253
- EXPECT_EQ(0, absl::any_cast<int&>(o));
254
- }
255
-
256
- template <typename Enabler, typename T, typename... Args>
257
- struct CanEmplaceAnyImpl : std::false_type {};
258
-
259
- template <typename T, typename... Args>
260
- struct CanEmplaceAnyImpl<
261
- absl::void_t<decltype(
262
- std::declval<absl::any&>().emplace<T>(std::declval<Args>()...))>,
263
- T, Args...> : std::true_type {};
264
-
265
- template <typename T, typename... Args>
266
- using CanEmplaceAny = CanEmplaceAnyImpl<void, T, Args...>;
267
-
268
- TEST(AnyTest, Emplace) {
269
- const CopyOnly copy_only{};
270
- absl::any o;
271
- EXPECT_TRUE((std::is_same<decltype(o.emplace<IntMoveOnlyCopyOnly>(
272
- 5, MoveOnly(), copy_only)),
273
- IntMoveOnlyCopyOnly&>::value));
274
- IntMoveOnlyCopyOnly& emplace_result =
275
- o.emplace<IntMoveOnlyCopyOnly>(5, MoveOnly(), copy_only);
276
- EXPECT_EQ(5, emplace_result.value);
277
- IntMoveOnlyCopyOnly& v = absl::any_cast<IntMoveOnlyCopyOnly&>(o);
278
- EXPECT_EQ(5, v.value);
279
- EXPECT_EQ(&emplace_result, &v);
280
-
281
- static_assert(!CanEmplaceAny<int, int, int>::value, "");
282
- static_assert(!CanEmplaceAny<MoveOnly, MoveOnly>::value, "");
283
- }
284
-
285
- TEST(AnyTest, EmplaceWithCV) {
286
- const CopyOnly copy_only{};
287
- absl::any o;
288
- EXPECT_TRUE(
289
- (std::is_same<decltype(o.emplace<const volatile IntMoveOnlyCopyOnly>(
290
- 5, MoveOnly(), copy_only)),
291
- IntMoveOnlyCopyOnly&>::value));
292
- IntMoveOnlyCopyOnly& emplace_result =
293
- o.emplace<const volatile IntMoveOnlyCopyOnly>(5, MoveOnly(), copy_only);
294
- EXPECT_EQ(5, emplace_result.value);
295
- IntMoveOnlyCopyOnly& v = absl::any_cast<IntMoveOnlyCopyOnly&>(o);
296
- EXPECT_EQ(5, v.value);
297
- EXPECT_EQ(&emplace_result, &v);
298
- }
299
-
300
- TEST(AnyTest, EmplaceWithFunction) {
301
- absl::any o;
302
- EXPECT_TRUE(
303
- (std::is_same<decltype(o.emplace<FunctionType>(FunctionToEmplace)),
304
- FunctionType*&>::value));
305
- FunctionType*& emplace_result = o.emplace<FunctionType>(FunctionToEmplace);
306
- EXPECT_EQ(&FunctionToEmplace, emplace_result);
307
- }
308
-
309
- TEST(AnyTest, EmplaceWithArray) {
310
- absl::any o;
311
- ArrayType ar = {5, 42};
312
- EXPECT_TRUE(
313
- (std::is_same<decltype(o.emplace<ArrayType>(ar)), DecayedArray&>::value));
314
- DecayedArray& emplace_result = o.emplace<ArrayType>(ar);
315
- EXPECT_EQ(&ar[0], emplace_result);
316
- }
317
-
318
- TEST(AnyTest, EmplaceIlist) {
319
- const CopyOnly copy_only{};
320
- absl::any o;
321
- EXPECT_TRUE((std::is_same<decltype(o.emplace<ListMoveOnlyCopyOnly>(
322
- {1, 2, 3, 4}, MoveOnly(), copy_only)),
323
- ListMoveOnlyCopyOnly&>::value));
324
- ListMoveOnlyCopyOnly& emplace_result =
325
- o.emplace<ListMoveOnlyCopyOnly>({1, 2, 3, 4}, MoveOnly(), copy_only);
326
- ListMoveOnlyCopyOnly& v = absl::any_cast<ListMoveOnlyCopyOnly&>(o);
327
- EXPECT_EQ(&v, &emplace_result);
328
- std::vector<int> expected_values = {1, 2, 3, 4};
329
- EXPECT_EQ(expected_values, v.values);
330
-
331
- static_assert(!CanEmplaceAny<int, std::initializer_list<int>>::value, "");
332
- static_assert(!CanEmplaceAny<MoveOnlyWithListConstructor,
333
- std::initializer_list<int>, int>::value,
334
- "");
335
- }
336
-
337
- TEST(AnyTest, EmplaceIlistWithCV) {
338
- const CopyOnly copy_only{};
339
- absl::any o;
340
- EXPECT_TRUE(
341
- (std::is_same<decltype(o.emplace<const volatile ListMoveOnlyCopyOnly>(
342
- {1, 2, 3, 4}, MoveOnly(), copy_only)),
343
- ListMoveOnlyCopyOnly&>::value));
344
- ListMoveOnlyCopyOnly& emplace_result =
345
- o.emplace<const volatile ListMoveOnlyCopyOnly>({1, 2, 3, 4}, MoveOnly(),
346
- copy_only);
347
- ListMoveOnlyCopyOnly& v = absl::any_cast<ListMoveOnlyCopyOnly&>(o);
348
- EXPECT_EQ(&v, &emplace_result);
349
- std::vector<int> expected_values = {1, 2, 3, 4};
350
- EXPECT_EQ(expected_values, v.values);
351
- }
352
-
353
- TEST(AnyTest, EmplaceNoArgs) {
354
- absl::any o;
355
- o.emplace<int>();
356
- EXPECT_EQ(0, absl::any_cast<int>(o));
357
- }
358
-
359
- TEST(AnyTest, ConversionConstruction) {
360
- {
361
- absl::any o = 5;
362
- EXPECT_EQ(5, absl::any_cast<int>(o));
363
- }
364
-
365
- {
366
- const CopyOnly copy_only(5);
367
- absl::any o = copy_only;
368
- EXPECT_EQ(5, absl::any_cast<CopyOnly&>(o).value);
369
- }
370
-
371
- static_assert(!std::is_convertible<MoveOnly, absl::any>::value, "");
372
- }
373
-
374
- TEST(AnyTest, ConversionAssignment) {
375
- {
376
- absl::any o;
377
- o = 5;
378
- EXPECT_EQ(5, absl::any_cast<int>(o));
379
- }
380
-
381
- {
382
- const CopyOnly copy_only(5);
383
- absl::any o;
384
- o = copy_only;
385
- EXPECT_EQ(5, absl::any_cast<CopyOnly&>(o).value);
386
- }
387
-
388
- static_assert(!std::is_assignable<MoveOnly, absl::any>::value, "");
389
- }
390
-
391
- // Suppress MSVC warnings.
392
- // 4521: multiple copy constructors specified
393
- // We wrote multiple of them to test that the correct overloads are selected.
394
- #ifdef _MSC_VER
395
- #pragma warning( push )
396
- #pragma warning( disable : 4521)
397
- #endif
398
-
399
- // Weird type for testing, only used to make sure we "properly" perfect-forward
400
- // when being placed into an absl::any (use the l-value constructor if given an
401
- // l-value rather than use the copy constructor).
402
- struct WeirdConstructor42 {
403
- explicit WeirdConstructor42(int value) : value(value) {}
404
-
405
- // Copy-constructor
406
- WeirdConstructor42(const WeirdConstructor42& other) : value(other.value) {}
407
-
408
- // L-value "weird" constructor (used when given an l-value)
409
- WeirdConstructor42(
410
- WeirdConstructor42& /*other*/) // NOLINT(runtime/references)
411
- : value(42) {}
412
-
413
- int value;
414
- };
415
- #ifdef _MSC_VER
416
- #pragma warning( pop )
417
- #endif
418
-
419
- TEST(AnyTest, WeirdConversionConstruction) {
420
- {
421
- const WeirdConstructor42 source(5);
422
- absl::any o = source; // Actual copy
423
- EXPECT_EQ(5, absl::any_cast<WeirdConstructor42&>(o).value);
424
- }
425
-
426
- {
427
- WeirdConstructor42 source(5);
428
- absl::any o = source; // Weird "conversion"
429
- EXPECT_EQ(42, absl::any_cast<WeirdConstructor42&>(o).value);
430
- }
431
- }
432
-
433
- TEST(AnyTest, WeirdConversionAssignment) {
434
- {
435
- const WeirdConstructor42 source(5);
436
- absl::any o;
437
- o = source; // Actual copy
438
- EXPECT_EQ(5, absl::any_cast<WeirdConstructor42&>(o).value);
439
- }
440
-
441
- {
442
- WeirdConstructor42 source(5);
443
- absl::any o;
444
- o = source; // Weird "conversion"
445
- EXPECT_EQ(42, absl::any_cast<WeirdConstructor42&>(o).value);
446
- }
447
- }
448
-
449
- struct Value {};
450
-
451
- TEST(AnyTest, AnyCastValue) {
452
- {
453
- absl::any o;
454
- o.emplace<int>(5);
455
- EXPECT_EQ(5, absl::any_cast<int>(o));
456
- EXPECT_EQ(5, absl::any_cast<int>(AsConst(o)));
457
- static_assert(
458
- std::is_same<decltype(absl::any_cast<Value>(o)), Value>::value, "");
459
- }
460
-
461
- {
462
- absl::any o;
463
- o.emplace<int>(5);
464
- EXPECT_EQ(5, absl::any_cast<const int>(o));
465
- EXPECT_EQ(5, absl::any_cast<const int>(AsConst(o)));
466
- static_assert(std::is_same<decltype(absl::any_cast<const Value>(o)),
467
- const Value>::value,
468
- "");
469
- }
470
- }
471
-
472
- TEST(AnyTest, AnyCastReference) {
473
- {
474
- absl::any o;
475
- o.emplace<int>(5);
476
- EXPECT_EQ(5, absl::any_cast<int&>(o));
477
- EXPECT_EQ(5, absl::any_cast<const int&>(AsConst(o)));
478
- static_assert(
479
- std::is_same<decltype(absl::any_cast<Value&>(o)), Value&>::value, "");
480
- }
481
-
482
- {
483
- absl::any o;
484
- o.emplace<int>(5);
485
- EXPECT_EQ(5, absl::any_cast<const int>(o));
486
- EXPECT_EQ(5, absl::any_cast<const int>(AsConst(o)));
487
- static_assert(std::is_same<decltype(absl::any_cast<const Value&>(o)),
488
- const Value&>::value,
489
- "");
490
- }
491
-
492
- {
493
- absl::any o;
494
- o.emplace<int>(5);
495
- EXPECT_EQ(5, absl::any_cast<int&&>(std::move(o)));
496
- static_assert(std::is_same<decltype(absl::any_cast<Value&&>(std::move(o))),
497
- Value&&>::value,
498
- "");
499
- }
500
-
501
- {
502
- absl::any o;
503
- o.emplace<int>(5);
504
- EXPECT_EQ(5, absl::any_cast<const int>(std::move(o)));
505
- static_assert(
506
- std::is_same<decltype(absl::any_cast<const Value&&>(std::move(o))),
507
- const Value&&>::value,
508
- "");
509
- }
510
- }
511
-
512
- TEST(AnyTest, AnyCastPointer) {
513
- {
514
- absl::any o;
515
- EXPECT_EQ(nullptr, absl::any_cast<char>(&o));
516
- o.emplace<int>(5);
517
- EXPECT_EQ(nullptr, absl::any_cast<char>(&o));
518
- o.emplace<char>('a');
519
- EXPECT_EQ('a', *absl::any_cast<char>(&o));
520
- static_assert(
521
- std::is_same<decltype(absl::any_cast<Value>(&o)), Value*>::value, "");
522
- }
523
-
524
- {
525
- absl::any o;
526
- EXPECT_EQ(nullptr, absl::any_cast<const char>(&o));
527
- o.emplace<int>(5);
528
- EXPECT_EQ(nullptr, absl::any_cast<const char>(&o));
529
- o.emplace<char>('a');
530
- EXPECT_EQ('a', *absl::any_cast<const char>(&o));
531
- static_assert(std::is_same<decltype(absl::any_cast<const Value>(&o)),
532
- const Value*>::value,
533
- "");
534
- }
535
- }
536
-
537
- TEST(AnyTest, MakeAny) {
538
- const CopyOnly copy_only{};
539
- auto o = absl::make_any<IntMoveOnlyCopyOnly>(5, MoveOnly(), copy_only);
540
- static_assert(std::is_same<decltype(o), absl::any>::value, "");
541
- EXPECT_EQ(5, absl::any_cast<IntMoveOnlyCopyOnly&>(o).value);
542
- }
543
-
544
- TEST(AnyTest, MakeAnyIList) {
545
- const CopyOnly copy_only{};
546
- auto o =
547
- absl::make_any<ListMoveOnlyCopyOnly>({1, 2, 3}, MoveOnly(), copy_only);
548
- static_assert(std::is_same<decltype(o), absl::any>::value, "");
549
- ListMoveOnlyCopyOnly& v = absl::any_cast<ListMoveOnlyCopyOnly&>(o);
550
- std::vector<int> expected_values = {1, 2, 3};
551
- EXPECT_EQ(expected_values, v.values);
552
- }
553
-
554
- // Test the use of copy constructor and operator=
555
- TEST(AnyTest, Copy) {
556
- InstanceTracker tracker_raii;
557
-
558
- {
559
- absl::any o(absl::in_place_type<CopyableOnlyInstance>, 123);
560
- CopyableOnlyInstance* f1 = absl::any_cast<CopyableOnlyInstance>(&o);
561
-
562
- absl::any o2(o);
563
- const CopyableOnlyInstance* f2 = absl::any_cast<CopyableOnlyInstance>(&o2);
564
- EXPECT_EQ(123, f2->value());
565
- EXPECT_NE(f1, f2);
566
-
567
- absl::any o3;
568
- o3 = o2;
569
- const CopyableOnlyInstance* f3 = absl::any_cast<CopyableOnlyInstance>(&o3);
570
- EXPECT_EQ(123, f3->value());
571
- EXPECT_NE(f2, f3);
572
-
573
- const absl::any o4(4);
574
- // copy construct from const lvalue ref.
575
- absl::any o5 = o4;
576
- EXPECT_EQ(4, absl::any_cast<int>(o4));
577
- EXPECT_EQ(4, absl::any_cast<int>(o5));
578
-
579
- // Copy construct from const rvalue ref.
580
- absl::any o6 = std::move(o4); // NOLINT
581
- EXPECT_EQ(4, absl::any_cast<int>(o4));
582
- EXPECT_EQ(4, absl::any_cast<int>(o6));
583
- }
584
- }
585
-
586
- TEST(AnyTest, Move) {
587
- InstanceTracker tracker_raii;
588
-
589
- absl::any any1;
590
- any1.emplace<CopyableOnlyInstance>(5);
591
-
592
- // This is a copy, so copy count increases to 1.
593
- absl::any any2 = any1;
594
- EXPECT_EQ(5, absl::any_cast<CopyableOnlyInstance&>(any1).value());
595
- EXPECT_EQ(5, absl::any_cast<CopyableOnlyInstance&>(any2).value());
596
- EXPECT_EQ(1, tracker_raii.copies());
597
-
598
- // This isn't a copy, so copy count doesn't increase.
599
- absl::any any3 = std::move(any2);
600
- EXPECT_EQ(5, absl::any_cast<CopyableOnlyInstance&>(any3).value());
601
- EXPECT_EQ(1, tracker_raii.copies());
602
-
603
- absl::any any4;
604
- any4 = std::move(any3);
605
- EXPECT_EQ(5, absl::any_cast<CopyableOnlyInstance&>(any4).value());
606
- EXPECT_EQ(1, tracker_raii.copies());
607
-
608
- absl::any tmp4(4);
609
- absl::any o4(std::move(tmp4)); // move construct
610
- EXPECT_EQ(4, absl::any_cast<int>(o4));
611
- o4 = *&o4; // self assign
612
- EXPECT_EQ(4, absl::any_cast<int>(o4));
613
- EXPECT_TRUE(o4.has_value());
614
-
615
- absl::any o5;
616
- absl::any tmp5(5);
617
- o5 = std::move(tmp5); // move assign
618
- EXPECT_EQ(5, absl::any_cast<int>(o5));
619
- }
620
-
621
- // Reset the ObjectOwner with an object of a different type
622
- TEST(AnyTest, Reset) {
623
- absl::any o;
624
- o.emplace<int>();
625
-
626
- o.reset();
627
- EXPECT_FALSE(o.has_value());
628
-
629
- o.emplace<char>();
630
- EXPECT_TRUE(o.has_value());
631
- }
632
-
633
- TEST(AnyTest, ConversionConstructionCausesOneCopy) {
634
- InstanceTracker tracker_raii;
635
- CopyableOnlyInstance counter(5);
636
- absl::any o(counter);
637
- EXPECT_EQ(5, absl::any_cast<CopyableOnlyInstance&>(o).value());
638
- EXPECT_EQ(1, tracker_raii.copies());
639
- }
640
-
641
- //////////////////////////////////
642
- // Tests for Exception Behavior //
643
- //////////////////////////////////
644
-
645
- #if defined(ABSL_USES_STD_ANY)
646
-
647
- // If using a std `any` implementation, we can't check for a specific message.
648
- #define ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(...) \
649
- ABSL_BASE_INTERNAL_EXPECT_FAIL((__VA_ARGS__), absl::bad_any_cast, \
650
- "")
651
-
652
- #else
653
-
654
- // If using the absl `any` implementation, we can rely on a specific message.
655
- #define ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(...) \
656
- ABSL_BASE_INTERNAL_EXPECT_FAIL((__VA_ARGS__), absl::bad_any_cast, \
657
- "Bad any cast")
658
-
659
- #endif // defined(ABSL_USES_STD_ANY)
660
-
661
- TEST(AnyTest, ThrowBadAlloc) {
662
- {
663
- absl::any a;
664
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<int&>(a));
665
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const int&>(a));
666
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<int&&>(absl::any{}));
667
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const int&&>(absl::any{}));
668
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<int>(a));
669
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const int>(a));
670
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<int>(absl::any{}));
671
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const int>(absl::any{}));
672
-
673
- // const absl::any operand
674
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const int&>(AsConst(a)));
675
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<int>(AsConst(a)));
676
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const int>(AsConst(a)));
677
- }
678
-
679
- {
680
- absl::any a(absl::in_place_type<int>);
681
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<float&>(a));
682
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const float&>(a));
683
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<float&&>(absl::any{}));
684
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(
685
- absl::any_cast<const float&&>(absl::any{}));
686
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<float>(a));
687
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const float>(a));
688
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<float>(absl::any{}));
689
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const float>(absl::any{}));
690
-
691
- // const absl::any operand
692
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const float&>(AsConst(a)));
693
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<float>(AsConst(a)));
694
- ABSL_ANY_TEST_EXPECT_BAD_ANY_CAST(absl::any_cast<const float>(AsConst(a)));
695
- }
696
- }
697
-
698
- class BadCopy {};
699
-
700
- struct BadCopyable {
701
- BadCopyable() = default;
702
- BadCopyable(BadCopyable&&) = default;
703
- BadCopyable(const BadCopyable&) {
704
- #ifdef ABSL_HAVE_EXCEPTIONS
705
- throw BadCopy();
706
- #else
707
- LOG(FATAL) << "Bad copy";
708
- #endif
709
- }
710
- };
711
-
712
- #define ABSL_ANY_TEST_EXPECT_BAD_COPY(...) \
713
- ABSL_BASE_INTERNAL_EXPECT_FAIL((__VA_ARGS__), BadCopy, "Bad copy")
714
-
715
- // Test the guarantees regarding exceptions in copy/assign.
716
- TEST(AnyTest, FailedCopy) {
717
- {
718
- const BadCopyable bad{};
719
- ABSL_ANY_TEST_EXPECT_BAD_COPY(absl::any{bad});
720
- }
721
-
722
- {
723
- absl::any src(absl::in_place_type<BadCopyable>);
724
- ABSL_ANY_TEST_EXPECT_BAD_COPY(absl::any{src});
725
- }
726
-
727
- {
728
- BadCopyable bad;
729
- absl::any target;
730
- ABSL_ANY_TEST_EXPECT_BAD_COPY(target = bad);
731
- }
732
-
733
- {
734
- BadCopyable bad;
735
- absl::any target(absl::in_place_type<BadCopyable>);
736
- ABSL_ANY_TEST_EXPECT_BAD_COPY(target = bad);
737
- EXPECT_TRUE(target.has_value());
738
- }
739
-
740
- {
741
- absl::any src(absl::in_place_type<BadCopyable>);
742
- absl::any target;
743
- ABSL_ANY_TEST_EXPECT_BAD_COPY(target = src);
744
- EXPECT_FALSE(target.has_value());
745
- }
746
-
747
- {
748
- absl::any src(absl::in_place_type<BadCopyable>);
749
- absl::any target(absl::in_place_type<BadCopyable>);
750
- ABSL_ANY_TEST_EXPECT_BAD_COPY(target = src);
751
- EXPECT_TRUE(target.has_value());
752
- }
753
- }
754
-
755
- // Test the guarantees regarding exceptions in emplace.
756
- TEST(AnyTest, FailedEmplace) {
757
- BadCopyable bad;
758
- absl::any target;
759
- ABSL_ANY_TEST_EXPECT_BAD_COPY(target.emplace<BadCopyable>(bad));
760
- }
761
-
762
- // GCC and Clang have a bug here.
763
- // Ine some cases, the exception seems to be thrown at the wrong time, and
764
- // target may contain a value.
765
- #ifdef __GNUC__
766
- TEST(AnyTest, DISABLED_FailedEmplaceInPlace) {
767
- #else
768
- TEST(AnyTest, FailedEmplaceInPlace) {
769
- #endif
770
- BadCopyable bad;
771
- absl::any target(absl::in_place_type<int>);
772
- ABSL_ANY_TEST_EXPECT_BAD_COPY(target.emplace<BadCopyable>(bad));
773
- EXPECT_FALSE(target.has_value());
774
- }
775
-
776
- } // namespace
777
-
778
- #endif // #if !defined(ABSL_USES_STD_ANY)