aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp/lambda.c
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2020-01-21 14:21:49 -0500
committerJason Merrill <jason@redhat.com>2020-01-21 16:42:10 -0500
commitad09440a09597c34e0b93498aad9d6ef0b8ca9ae (patch)
treef289edc6a5ba5ab65034e39dafef9bab5f504fb8 /gcc/cp/lambda.c
parent276265195a4e7362b34ac512f3bc0ad5a974dcff (diff)
downloadgcc-ad09440a09597c34e0b93498aad9d6ef0b8ca9ae.zip
gcc-ad09440a09597c34e0b93498aad9d6ef0b8ca9ae.tar.gz
gcc-ad09440a09597c34e0b93498aad9d6ef0b8ca9ae.tar.bz2
PR c++/60855 - ICE with sizeof VLA capture.
For normal captures we usually look through them within unevaluated context, but that doesn't work here; trying to take the sizeof of the array in the enclosing scope tries and fails to evaluate a SAVE_EXPR from the enclosing scope. * lambda.c (is_lambda_ignored_entity): Don't look past VLA capture.
Diffstat (limited to 'gcc/cp/lambda.c')
-rw-r--r--gcc/cp/lambda.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/gcc/cp/lambda.c b/gcc/cp/lambda.c
index 50fb144..4f39f99 100644
--- a/gcc/cp/lambda.c
+++ b/gcc/cp/lambda.c
@@ -1327,8 +1327,9 @@ lambda_static_thunk_p (tree fn)
bool
is_lambda_ignored_entity (tree val)
{
- /* Look past normal capture proxies. */
- if (is_normal_capture_proxy (val))
+ /* Look past normal, non-VLA capture proxies. */
+ if (is_normal_capture_proxy (val)
+ && !variably_modified_type_p (TREE_TYPE (val), NULL_TREE))
return true;
/* Always ignore lambda fields, their names are only for debugging. */