From: Daniel Jasper Date: Tue, 19 May 2015 11:51:39 +0000 (+0000) Subject: clang-format: Improve for-loop formatting. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=f723d21c8786d0d37c333e92a13a3617de4f00cf;p=clang clang-format: Improve for-loop formatting. Before: for (SmallVectorImpl::iterator I = Container.begin(), E = Container.end(); I != E; ++I) After: for (SmallVectorImpl::iterator I = Container.begin(), E = Container.end(); I != E; ++I) This fixes llvm.org/PR23544. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@237688 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Format/TokenAnnotator.cpp b/lib/Format/TokenAnnotator.cpp index 8088ff667e..a20790e894 100644 --- a/lib/Format/TokenAnnotator.cpp +++ b/lib/Format/TokenAnnotator.cpp @@ -568,7 +568,8 @@ private: case tok::comma: if (Contexts.back().InCtorInitializer) Tok->Type = TT_CtorInitializerComma; - else if (Contexts.back().FirstStartOfName && Contexts.size() == 1) { + else if (Contexts.back().FirstStartOfName && + (Contexts.size() == 1 || Line.First->is(tok::kw_for))) { Contexts.back().FirstStartOfName->PartOfMultiVariableDeclStmt = true; Line.IsMultiVariableDeclStmt = true; } diff --git a/unittests/Format/FormatTest.cpp b/unittests/Format/FormatTest.cpp index d035043b0f..5a568f4c0b 100644 --- a/unittests/Format/FormatTest.cpp +++ b/unittests/Format/FormatTest.cpp @@ -557,6 +557,11 @@ TEST_F(FormatTest, FormatsForLoop) { " I = FD->getDeclsInPrototypeScope().begin(),\n" " E = FD->getDeclsInPrototypeScope().end();\n" " I != E; ++I) {\n}"); + verifyFormat("for (SmallVectorImpl::iterator\n" + " I = Container.begin(),\n" + " E = Container.end();\n" + " I != E; ++I) {\n}", + getLLVMStyleWithColumns(76)); verifyFormat( "for (aaaaaaaaaaaaaaaaa aaaaaaaaaaa = aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa;\n"