While looking at something else I noticed that we were passing 0 to the "nonclass" parameter here; we might as well pass 1, since capture proxies are always at block scope.
Tested x86_64-pc-linux-gnu, applying to trunk. * pt.c (tsubst_expr) [DECL_EXPR]: Ignore class-scope bindings when looking up a capture proxy. --- gcc/cp/pt.c | 5 +++-- gcc/cp/ChangeLog | 5 +++++ 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 3b378ee9ff4..a5b9fa67666 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -16903,8 +16903,9 @@ tsubst_expr (tree t, tree args, tsubst_flags_t complain, tree in_decl, tree inst; if (!DECL_PACK_P (decl)) { - inst = lookup_name_real (DECL_NAME (decl), 0, 0, - /*block_p=*/true, 0, LOOKUP_HIDDEN); + inst = lookup_name_real (DECL_NAME (decl), /*prefer_type*/0, + /*nonclass*/1, /*block_p=*/true, + /*ns_only*/0, LOOKUP_HIDDEN); gcc_assert (inst != decl && is_capture_proxy (inst)); } else if (is_normal_capture_proxy (decl)) diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 46557bec5c2..3dfaa75cbb5 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2018-12-14 Jason Merrill <ja...@redhat.com> + + * pt.c (tsubst_expr) [DECL_EXPR]: Ignore class-scope bindings when + looking up a capture proxy. + 2018-12-13 Marek Polacek <pola...@redhat.com> PR c++/88216 - ICE with class type in non-type template parameter. base-commit: 95f61091a1264856c1128b67791843a791cb415f -- 2.19.2