diff options
author | Daniel Jasper <djasper@google.com> | 2013-10-20 18:15:30 +0000 |
---|---|---|
committer | Daniel Jasper <djasper@google.com> | 2013-10-20 18:15:30 +0000 |
commit | d46e07e26e5256327eb38b092057b58547310b18 (patch) | |
tree | ecb6ae54a9827a3b8f7fa8c230e6c4f6bf91613e /clang/lib | |
parent | e77b0424fdc42ccaa627f30d97b2307292ab036e (diff) | |
download | bcm5719-llvm-d46e07e26e5256327eb38b092057b58547310b18.tar.gz bcm5719-llvm-d46e07e26e5256327eb38b092057b58547310b18.zip |
clang-format: Better understand Lambda poarameters.
Before:
auto PointerBinding = [](const char * S) {};
After:
auto PointerBinding = [](const char *S) {};
This fixes llvm.org/PR17618.
llvm-svn: 193054
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/Format/TokenAnnotator.cpp | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/clang/lib/Format/TokenAnnotator.cpp b/clang/lib/Format/TokenAnnotator.cpp index 7e794a3d2d5..733f70d7208 100644 --- a/clang/lib/Format/TokenAnnotator.cpp +++ b/clang/lib/Format/TokenAnnotator.cpp @@ -96,8 +96,15 @@ private: } if (Left->Previous && Left->Previous->isOneOf(tok::kw_static_assert, - tok::kw_if, tok::kw_while)) + tok::kw_if, tok::kw_while)) { + // static_assert, if and while usually contain expressions. Contexts.back().IsExpression = true; + } else if (Left->Previous && Left->Previous->is(tok::r_square) && + Left->Previous->MatchingParen && + Left->Previous->MatchingParen->Type == TT_LambdaLSquare) { + // This is a parameter list of a lambda expression. + Contexts.back().IsExpression = false; + } if (StartsObjCMethodExpr) { Contexts.back().ColonIsObjCMethodExpr = true; |