diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2012-09-20 01:40:23 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2012-09-20 01:40:23 +0000 |
commit | 8f5e9830297c8148827dc46d759d59b9093407dd (patch) | |
tree | 1b88799e0da613d36d625517a069be9c776b33b7 /clang/lib/Sema/SemaLambda.cpp | |
parent | a31a89a38e8a1eec567f190611b97902029e722c (diff) | |
download | bcm5719-llvm-8f5e9830297c8148827dc46d759d59b9093407dd.tar.gz bcm5719-llvm-8f5e9830297c8148827dc46d759d59b9093407dd.zip |
Handle lambdas where the lambda-declarator is an explicit "(void)". PR13854.
llvm-svn: 164274
Diffstat (limited to 'clang/lib/Sema/SemaLambda.cpp')
-rw-r--r-- | clang/lib/Sema/SemaLambda.cpp | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaLambda.cpp b/clang/lib/Sema/SemaLambda.cpp index 489c895c996..15cd2a73e7f 100644 --- a/clang/lib/Sema/SemaLambda.cpp +++ b/clang/lib/Sema/SemaLambda.cpp @@ -410,9 +410,15 @@ void Sema::ActOnStartOfLambdaDefinition(LambdaIntroducer &Intro, = MethodTyInfo->getType()->getAs<FunctionType>()->getResultType() != Context.DependentTy; - Params.reserve(FTI.NumArgs); - for (unsigned i = 0, e = FTI.NumArgs; i != e; ++i) - Params.push_back(cast<ParmVarDecl>(FTI.ArgInfo[i].Param)); + if (FTI.NumArgs == 1 && !FTI.isVariadic && FTI.ArgInfo[0].Ident == 0 && + cast<ParmVarDecl>(FTI.ArgInfo[0].Param)->getType()->isVoidType()) { + // Empty arg list, don't push any params. + checkVoidParamDecl(cast<ParmVarDecl>(FTI.ArgInfo[0].Param)); + } else { + Params.reserve(FTI.NumArgs); + for (unsigned i = 0, e = FTI.NumArgs; i != e; ++i) + Params.push_back(cast<ParmVarDecl>(FTI.ArgInfo[i].Param)); + } // Check for unexpanded parameter packs in the method type. if (MethodTyInfo->getType()->containsUnexpandedParameterPack()) |