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

Reply via email to