diff options
author | Jason Merrill <jason@redhat.com> | 2022-05-31 16:31:35 -0400 |
---|---|---|
committer | Jason Merrill <jason@redhat.com> | 2022-06-01 15:20:44 -0400 |
commit | e2e471d83d16449a325315c0f33dc52b90ce0fac (patch) | |
tree | 00d48a812db47add8febf8e3ef4ba4d78ba5c45e /gcc/cp/parser.cc | |
parent | 72e52b88582e738c8b8bde5f85af63d3a0e15d2b (diff) | |
download | gcc-e2e471d83d16449a325315c0f33dc52b90ce0fac.zip gcc-e2e471d83d16449a325315c0f33dc52b90ce0fac.tar.gz gcc-e2e471d83d16449a325315c0f33dc52b90ce0fac.tar.bz2 |
c++: auto and dependent member name [PR105734]
In r12-3643 I improved our handling of type names after . or -> when
unqualified lookup doesn't find anything, but it needs to handle auto
specially.
PR c++/105734
gcc/cp/ChangeLog:
* parser.cc (cp_parser_postfix_dot_deref_expression): Use typeof
if the expression has auto type.
gcc/testsuite/ChangeLog:
* g++.dg/cpp0x/auto57.C: New test.
Diffstat (limited to 'gcc/cp/parser.cc')
-rw-r--r-- | gcc/cp/parser.cc | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/cp/parser.cc b/gcc/cp/parser.cc index 0eefa74..3fc7344 100644 --- a/gcc/cp/parser.cc +++ b/gcc/cp/parser.cc @@ -8262,7 +8262,7 @@ cp_parser_postfix_dot_deref_expression (cp_parser *parser, tree type = TREE_TYPE (postfix_expression); /* If we don't have a (type-dependent) object of class type, use typeof to figure out the type of the object. */ - if (type == NULL_TREE) + if (type == NULL_TREE || is_auto (type)) type = finish_typeof (postfix_expression); parser->context->object_type = type; } |