public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug c++/106969] New: member function constness incorrectly propagates to local class member function return type deduction
@ 2022-09-19 17:13 enolan at alumni dot cmu.edu
  2022-09-19 17:30 ` [Bug c++/106969] [12/13 Regression] " pinskia at gcc dot gnu.org
                   ` (6 more replies)
  0 siblings, 7 replies; 8+ messages in thread
From: enolan at alumni dot cmu.edu @ 2022-09-19 17:13 UTC (permalink / raw)
  To: gcc-bugs

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=106969

            Bug ID: 106969
           Summary: member function constness incorrectly propagates to
                    local class member function return type deduction
           Product: gcc
           Version: 12.2.1
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: c++
          Assignee: unassigned at gcc dot gnu.org
          Reporter: enolan at alumni dot cmu.edu
  Target Milestone: ---

When using decltype in the return type of a member function of a local class
defined inside of a const member function, the type of 'this' seems to be
deduced as a pointer to const, when it should be a pointer to non-const.

Compiler explorer link: https://godbolt.org/z/9KKbrzq1e

Minimal reproduction:

struct Context
{
    void
    action() const
    {
        struct
        {
            int wrapped;
            decltype( & wrapped ) get() { return &wrapped; }
        } t;

        *t.get()= 42;
    }
};

Note that if the local class member function definition is changed to:

            auto get() -> decltype( & wrapped ) { return &wrapped; }

Then the bug no longer appears.

> the exact version of gcc

gcc version 12.2.1 20220819 (Red Hat 12.2.1-2) (GCC)

> the system type

Fedora release 38 (Rawhide)

> the options given when GCC was configured/built

Configured with: ../configure --enable-bootstrap
--enable-languages=c,c++,fortran,objc,obj-c++,ada,go,d,lto --prefix=/usr
--mandir=/usr/share/man --infodir=/usr/share/info
--with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-shared
--enable-threads=posix --enable-checking=release --enable-multilib
--with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions
--enable-gnu-unique-object --enable-linker-build-id
--with-gcc-major-version-only --enable-libstdcxx-backtrace
--with-linker-hash-style=gnu --enable-plugin --enable-initfini-array
--with-isl=/builddir/build/BUILD/gcc-12.2.1-20220819/obj-x86_64-redhat-linux/isl-install
--enable-offload-targets=nvptx-none --without-cuda-driver
--enable-offload-defaulted --enable-gnu-indirect-function --enable-cet
--with-tune=generic --with-arch_32=i686 --build=x86_64-redhat-linux
--with-build-config=bootstrap-lto --enable-link-serialization=1

> the complete command line that triggers the bug

g++ poc.cpp

> the compiler output

poc.cpp: In member function ‘void Context::action() const’:
poc.cpp:12:17: error: assignment of read-only location ‘* t.Context::action()
const::<unnamed struct>::get()’
   12 |         *t.get()= 42;
      |         ~~~~~~~~^~~~

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2023-04-28 22:15 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-09-19 17:13 [Bug c++/106969] New: member function constness incorrectly propagates to local class member function return type deduction enolan at alumni dot cmu.edu
2022-09-19 17:30 ` [Bug c++/106969] [12/13 Regression] " pinskia at gcc dot gnu.org
2022-09-20 14:33 ` ppalka at gcc dot gnu.org
2022-10-18  8:43 ` rguenth at gcc dot gnu.org
2023-03-24 18:51 ` cvs-commit at gcc dot gnu.org
2023-03-24 18:52 ` [Bug c++/106969] [12 " ppalka at gcc dot gnu.org
2023-04-28 22:13 ` cvs-commit at gcc dot gnu.org
2023-04-28 22:15 ` ppalka at gcc dot gnu.org

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).