Tested x86_64-pc-linux-gnu, applying to trunk.
-- >8 --
This test I got today was just fixed by r16-8027 earlier today.
gcc/testsuite/ChangeLog:
* g++.dg/reflect/define_static_array5.C: New test.
---
.../g++.dg/reflect/define_static_array5.C | 20 +++++++++++++++++++
1 file changed, 20 insertions(+)
create mode 100644 gcc/testsuite/g++.dg/reflect/define_static_array5.C
diff --git a/gcc/testsuite/g++.dg/reflect/define_static_array5.C
b/gcc/testsuite/g++.dg/reflect/define_static_array5.C
new file mode 100644
index 00000000000..c7756024e76
--- /dev/null
+++ b/gcc/testsuite/g++.dg/reflect/define_static_array5.C
@@ -0,0 +1,20 @@
+// { dg-do compile { target c++26 } }
+// { dg-additional-options "-freflection" }
+
+#include <meta>
+#include <ranges>
+
+static_assert(
+ std::ranges::equal(
+ (std::vector {1, 2} | std::views::transform([](auto z) { return
std::pair(z, z); })),
+ std::vector {std::pair{1, 1}, std::pair{2, 2}}));
+static_assert(
+ std::ranges::equal(
+ std::define_static_array(
+ (std::vector {1, 2} | std::views::transform([](auto z) { return
std::pair(z, z); }))),
+ std::vector {std::pair{1, 1}, std::pair{2, 2}}));
+static_assert(
+ std::ranges::equal(
+ std::define_static_array(
+ (std::vector {1, 2} | std::views::transform([](auto z) { return z;
}))),
+ std::vector {1, 2}));
base-commit: 8b626332027ad1ff21f33a5b465e02fcab0cbff9
--
2.53.0