On Sat, 20 Apr 2024, Nathaniel Shead wrote: > Bootstrapped and regtested on x86_64-pc-linux-gnu, OK for trunk? > > -- >8 -- > > A class allocation member function is implicitly 'static' by > [class.free] p3, so cannot have an explicit object parameter. > > PR c++/114078 > > gcc/cp/ChangeLog: > > * decl.cc (grokdeclarator): Check allocation functions for xobj > parameters. > > gcc/testsuite/ChangeLog: > > * g++.dg/cpp23/explicit-obj-ops-alloc.C: New test.
LGTM > > Signed-off-by: Nathaniel Shead <nathanielosh...@gmail.com> > --- > gcc/cp/decl.cc | 6 ++++++ > gcc/testsuite/g++.dg/cpp23/explicit-obj-ops-alloc.C | 11 +++++++++++ > 2 files changed, 17 insertions(+) > create mode 100644 gcc/testsuite/g++.dg/cpp23/explicit-obj-ops-alloc.C > > diff --git a/gcc/cp/decl.cc b/gcc/cp/decl.cc > index 65ab64885ff..2af026d255d 100644 > --- a/gcc/cp/decl.cc > +++ b/gcc/cp/decl.cc > @@ -13728,6 +13728,12 @@ grokdeclarator (const cp_declarator *declarator, > inform (DECL_SOURCE_LOCATION (xobj_parm), > "explicit object parameter declared here"); > } > + if (unqualified_id > + && identifier_p (unqualified_id) > + && IDENTIFIER_NEWDEL_OP_P (unqualified_id)) > + error_at (DECL_SOURCE_LOCATION (xobj_parm), > + "%qD cannot be an explicit object member " > + "function", unqualified_id); > } > } > tree pushed_scope = NULL_TREE; > diff --git a/gcc/testsuite/g++.dg/cpp23/explicit-obj-ops-alloc.C > b/gcc/testsuite/g++.dg/cpp23/explicit-obj-ops-alloc.C > new file mode 100644 > index 00000000000..8a277db7ef5 > --- /dev/null > +++ b/gcc/testsuite/g++.dg/cpp23/explicit-obj-ops-alloc.C > @@ -0,0 +1,11 @@ > +// PR c++/114078 > +// { dg-do compile { target c++23 } } > + > +using size_t = decltype(sizeof(0)); > + > +struct S { > + void* operator new(this size_t); // { dg-error "explicit object" } > + void* operator new[](this size_t); // { dg-error "explicit object" } > + void operator delete(this void*); // { dg-error "explicit object" } > + void operator delete[](this void*); // { dg-error "explicit object" } > +}; > -- > 2.43.2 > >