]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: clobber class new-expressions
authorJason Merrill <jason@redhat.com>
Thu, 18 Sep 2025 11:10:55 +0000 (13:10 +0200)
committerJason Merrill <jason@redhat.com>
Thu, 18 Sep 2025 21:46:37 +0000 (23:46 +0200)
Since Jakub's P2795R5 work removes the initial clobber from constructors,
let's add a clobber for new of all non-empty classes.

gcc/cp/ChangeLog:

* init.cc (build_new_1): Clobber classes.

gcc/testsuite/ChangeLog:

* g++.dg/analyzer/pr97116.C: Adjust diagnostic.
* g++.dg/warn/Warray-bounds-20.C: Likewise.

gcc/cp/init.cc
gcc/testsuite/g++.dg/analyzer/pr97116.C
gcc/testsuite/g++.dg/warn/Warray-bounds-20.C

index c950c363f59c327b3f2ffb5e61253718d340df25..3fe476d7eec7343eac36be8aae50b457026f8de0 100644 (file)
@@ -3566,9 +3566,7 @@ build_new_1 (vec<tree, va_gc> **placement, tree type, tree nelts,
     = (std_placement && flag_lifetime_dse > 1
        && !processing_template_decl
        && !is_empty_type (elt_type)
-       && !*init
-       && (!CLASS_TYPE_P (elt_type)
-          || type_has_non_user_provided_default_constructor (elt_type)));
+       && (!*init || CLASS_TYPE_P (elt_type)));
 
   /* In the simple case, we can stop now.  */
   pointer_type = build_pointer_type (type);
index 1c404c2ceb233f0009dee3700d45d51d2eb90c0f..06ee8623f43acfd608fbee190422166aac40bad5 100644 (file)
@@ -3,7 +3,7 @@
 
 struct foo
 {
-  foo (int i) : m_i (i) {} // { dg-message "argument 'this' of 'foo::foo\\(int\\)' must be non-null" "note" }
+  foo (int i) : m_i (i) {}
 
   int get () const { return m_i; } // { dg-message "argument 'this' of '\[^\n\]*' must be non-null" "note" }
   
@@ -15,8 +15,7 @@ struct foo
 
 void test_1 (void)
 {
-  foo *p = new(NULL) foo (42); // { dg-warning "non-null expected" "warning" }
-  // { dg-message "argument 'this'( \\(\[^\n\]*\\))? NULL where non-null expected" "final event" { target *-*-* } .-1 }
+  foo *p = new(NULL) foo (42); // { dg-warning "dereference of NULL" "warning" }
 }
 
 int test_2 (void)
index 5fc552930747b8bd74d4ee6db9624dc8537eb92a..36f8046fed7bd48b1a9faf9bbd42073f8227348b 100644 (file)
@@ -39,7 +39,7 @@ void warn_derived_ctor_access_new_decl ()
                               // { dg-message "at offset 1 into object 'a' of size 20" "LP64 note" { target ilp32} .-1 }
   char *p = a;
   ++p;
-  D1 *q = new (p) D1;
+  D1 *q = new (p) D1;          // { dg-warning "-Warray-bounds" }
   sink (q);
 }
 
@@ -47,7 +47,7 @@ void warn_derived_ctor_access_new_alloc ()
 {
   char *p = (char*)operator new (sizeof (D1));    // { dg-message "at offset 1 into object of size \\d+ allocated by '\[^\n\r]*operator new\[^\n\r]*'" "note" }
   ++p;
-  D1 *q = new (p) D1;
+  D1 *q = new (p) D1;          // { dg-warning "-Warray-bounds" }
   sink (q);
 }