aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-ssa-loop-im.c
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2019-01-29 21:43:04 -0500
committerJason Merrill <jason@gcc.gnu.org>2019-01-29 21:43:04 -0500
commit538a530848375deb14495fae5a5ccf5ae5daedba (patch)
tree2014ffc7cf9d736a2f0e7a17bddbaa3c9087d660 /gcc/tree-ssa-loop-im.c
parentdca2770bc073353e621e426d4803b8ea16382b5a (diff)
downloadgcc-538a530848375deb14495fae5a5ccf5ae5daedba.zip
gcc-538a530848375deb14495fae5a5ccf5ae5daedba.tar.gz
gcc-538a530848375deb14495fae5a5ccf5ae5daedba.tar.bz2
PR c++/86943 - wrong code converting lambda to function pointer.
In this PR, instantiating the static thunk returned from the generic lambda conversion function template was using normal overload resolution, which meant calling an extra constructor when forwarding its argument. Fixed by special-casing thunk calls significantly more. * lambda.c (maybe_add_lambda_conv_op): Use a template-id in the call. Only forward parms for decltype. * pt.c (tsubst_copy_and_build) [CALL_EXPR]: Handle CALL_FROM_THUNK_P specially. * typeck.c (check_return_expr): Don't mess with a thunk call. From-SVN: r268377
Diffstat (limited to 'gcc/tree-ssa-loop-im.c')
0 files changed, 0 insertions, 0 deletions