summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorDaniel Jasper <djasper@google.com>2013-10-20 18:15:30 +0000
committerDaniel Jasper <djasper@google.com>2013-10-20 18:15:30 +0000
commitd46e07e26e5256327eb38b092057b58547310b18 (patch)
treeecb6ae54a9827a3b8f7fa8c230e6c4f6bf91613e /clang/lib
parente77b0424fdc42ccaa627f30d97b2307292ab036e (diff)
downloadbcm5719-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.cpp9
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;
OpenPOWER on IntegriCloud