diff options
author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2016-12-13 06:20:44 +0000 |
---|---|---|
committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2016-12-13 06:20:44 +0000 |
commit | b73b600f9a23ed8d38de2696c66eaaa227531145 (patch) | |
tree | 4483d5bb3eb39b1c27c8654fdbf4bc96d1521503 | |
parent | 41eb5a9a7774fffc98c7ea8b3fc4931014a5b612 (diff) | |
download | gcc-b73b600f9a23ed8d38de2696c66eaaa227531145.tar.gz |
PR c++/78761
* cp-demangle.c (cplus_demangle_type): Demangle Dc as decltype(auto).
* testsuite/demangle-expected: Add test for decltype(auto).
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-6-branch@243594 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | libiberty/ChangeLog | 6 | ||||
-rw-r--r-- | libiberty/cp-demangle.c | 6 | ||||
-rw-r--r-- | libiberty/testsuite/demangle-expected | 3 |
3 files changed, 14 insertions, 1 deletions
diff --git a/libiberty/ChangeLog b/libiberty/ChangeLog index dc904ecdb69..4bdb1a2c8fc 100644 --- a/libiberty/ChangeLog +++ b/libiberty/ChangeLog @@ -1,3 +1,9 @@ +2016-12-13 Jakub Jelinek <jakub@redhat.com> + + PR c++/78761 + * cp-demangle.c (cplus_demangle_type): Demangle Dc as decltype(auto). + * testsuite/demangle-expected: Add test for decltype(auto). + 2016-12-12 Nathan Sidwell <nathan@acm.org> PR c++/78252 diff --git a/libiberty/cp-demangle.c b/libiberty/cp-demangle.c index db3be51505c..78e59788478 100644 --- a/libiberty/cp-demangle.c +++ b/libiberty/cp-demangle.c @@ -2552,7 +2552,11 @@ cplus_demangle_type (struct d_info *di) /* auto */ ret = d_make_name (di, "auto", 4); break; - + case 'c': + /* decltype(auto) */ + ret = d_make_name (di, "decltype(auto)", 14); + break; + case 'f': /* 32-bit decimal floating point */ ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[26]); diff --git a/libiberty/testsuite/demangle-expected b/libiberty/testsuite/demangle-expected index 577ca6ba525..157d2ee9699 100644 --- a/libiberty/testsuite/demangle-expected +++ b/libiberty/testsuite/demangle-expected @@ -4085,6 +4085,9 @@ decltype (new auto({parm#1})) f<int>(int) _Z1fIiERDaRKT_S1_ auto& f<int>(int const&, int) --format=gnu-v3 +_Z1gIiEDcRKT_S0_ +decltype(auto) g<int>(int const&, int) +--format=gnu-v3 _Z1gILi1EEvR1AIXT_EER1BIXscbT_EE void g<1>(A<1>&, B<static_cast<bool>(1)>&) --format=gnu-v3 |