mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-05 16:51:13 +08:00
c++: tweak to (*(fn))() patch [PR104618]
Other callers of mark_single_function might also want to look through these wrapapers. PR c++/104618 gcc/cp/ChangeLog: * decl2.cc (mark_single_function): Look through parens and location wrapper. * typeck.cc (cp_build_addr_expr_1): Not here.
This commit is contained in:
parent
b7dbe870bc
commit
03e0c807ef
@ -5737,6 +5737,9 @@ decl_dependent_p (tree decl)
|
||||
bool
|
||||
mark_single_function (tree expr, tsubst_flags_t complain)
|
||||
{
|
||||
expr = maybe_undo_parenthesized_ref (expr);
|
||||
expr = tree_strip_any_location_wrapper (expr);
|
||||
|
||||
if (is_overloaded_fn (expr) == 1
|
||||
&& !mark_used (expr, complain)
|
||||
&& (complain & tf_error))
|
||||
|
@ -6884,9 +6884,7 @@ cp_build_addr_expr_1 (tree arg, bool strict_lvalue, tsubst_flags_t complain)
|
||||
so we can just form an ADDR_EXPR with the correct type. */
|
||||
if (processing_template_decl || TREE_CODE (arg) != COMPONENT_REF)
|
||||
{
|
||||
tree stripped_arg
|
||||
= tree_strip_any_location_wrapper (maybe_undo_parenthesized_ref (arg));
|
||||
if (!mark_single_function (stripped_arg, complain))
|
||||
if (!mark_single_function (arg, complain))
|
||||
return error_mark_node;
|
||||
val = build_address (arg);
|
||||
if (TREE_CODE (arg) == OFFSET_REF)
|
||||
|
Loading…
x
Reference in New Issue
Block a user