diff options
author | Jason Merrill <jason@redhat.com> | 2020-12-19 13:10:01 -0500 |
---|---|---|
committer | Jason Merrill <jason@redhat.com> | 2020-12-21 15:46:14 -0500 |
commit | 71690493322238d0fb9be776d9fceed0a7bf727e (patch) | |
tree | 2a0fe142b2b6b1321161ea991f986105117ab7a3 /libiberty/cp-demangle.c | |
parent | 0e1d4b3bfe260667fb8e055ebff2b34d8a2ec253 (diff) | |
download | gcc-71690493322238d0fb9be776d9fceed0a7bf727e.zip gcc-71690493322238d0fb9be776d9fceed0a7bf727e.tar.gz gcc-71690493322238d0fb9be776d9fceed0a7bf727e.tar.bz2 |
c++: Fix demangling of x.operator type
d_operator_name decides whether "cv" indicates a cast or a conversion
operator based on is_expression. "on" specifies that we want the conversion
operator.
libiberty/ChangeLog:
* cp-demangle.c (d_unqualified_name): Clear is_expression.
* testsuite/demangle-expected: Add tests.
Diffstat (limited to 'libiberty/cp-demangle.c')
-rw-r--r-- | libiberty/cp-demangle.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/libiberty/cp-demangle.c b/libiberty/cp-demangle.c index a9f8e75..96f43b6 100644 --- a/libiberty/cp-demangle.c +++ b/libiberty/cp-demangle.c @@ -1632,9 +1632,15 @@ d_unqualified_name (struct d_info *di) ret = d_source_name (di); else if (IS_LOWER (peek)) { + int was_expr = di->is_expression; if (peek == 'o' && d_peek_next_char (di) == 'n') - d_advance (di, 2); + { + d_advance (di, 2); + /* Treat cv as naming a conversion operator. */ + di->is_expression = 0; + } ret = d_operator_name (di); + di->is_expression = was_expr; if (ret != NULL && ret->type == DEMANGLE_COMPONENT_OPERATOR) { di->expansion += sizeof "operator" + ret->u.s_operator.op->len - 2; |