]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
d: Side effects not evaluated for array literals on stack [PR120096]
authorIain Buclaw <ibuclaw@gdcproject.org>
Tue, 27 Jan 2026 20:51:40 +0000 (21:51 +0100)
committerIain Buclaw <ibuclaw@gdcproject.org>
Tue, 27 Jan 2026 22:35:24 +0000 (23:35 +0100)
PR d/120096

gcc/d/ChangeLog:

* expr.cc (ExprVisitor::visit (ArrayLiteralExp *)): Include saved side
effects in expression result.

gcc/testsuite/ChangeLog:

* gdc.dg/torture/pr120096.d: New test.

gcc/d/expr.cc
gcc/testsuite/gdc.dg/torture/pr120096.d [new file with mode: 0644]

index 9d698644c3833456f1275b6bbd975519e5fe2232..bc1f788d0221c637d3ce0490f12f05e591a8f27d 100644 (file)
@@ -2674,8 +2674,9 @@ public:
        /* Array literal for a `scope' dynamic array.  */
        gcc_assert (tb->ty == TY::Tarray);
        ctor = force_target_expr (ctor);
-       this->result_ = d_array_value (type, size_int (e->elements->length),
-                                      build_address (ctor));
+       ctor = d_array_value (type, size_int (e->elements->length),
+                             build_address (force_target_expr (ctor)));
+       this->result_ = compound_expr (saved_elems, ctor);
       }
     else
       {
diff --git a/gcc/testsuite/gdc.dg/torture/pr120096.d b/gcc/testsuite/gdc.dg/torture/pr120096.d
new file mode 100644 (file)
index 0000000..7aaae2d
--- /dev/null
@@ -0,0 +1,18 @@
+// { dg-do run }
+// { dg-additional-options "-fpreview=dip1000" }
+// { dg-skip-if "needs gcc/config.d" { ! d_runtime } }
+struct S
+{
+    this(int p) nothrow @nogc @safe
+    { f = p; }
+    int f;
+}
+
+int main() nothrow @nogc @safe
+{
+    scope S[] sa = [S(1), S(2)];
+
+    assert(sa[0].f == 1);
+    assert(sa[1].f == 2);
+    return 0;
+}