From 12ef4e59effbad1f76bbe0b5011d45e777436b4c Mon Sep 17 00:00:00 2001 From: Daniel Jasper Date: Thu, 21 Feb 2013 21:33:55 +0000 Subject: Consistently put {} onto the same line for empty functions. This fixes llvm.org/PR15167. Before: LLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLL() : AAAAAAAA(10), BBBBBBBBB(10) { } LLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLL() : AAAAAAAA(10) {} After: LLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLL() : AAAAAAAA(10), BBBBBBBBB(10) {} LLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLL() : AAAAAAAA(10) {} llvm-svn: 175800 --- clang/lib/Format/Format.cpp | 36 ++++++++++++++++++------------------ clang/lib/Format/TokenAnnotator.cpp | 4 ++-- 2 files changed, 20 insertions(+), 20 deletions(-) (limited to 'clang/lib/Format') diff --git a/clang/lib/Format/Format.cpp b/clang/lib/Format/Format.cpp index 2bd53322276..880be39b1c3 100644 --- a/clang/lib/Format/Format.cpp +++ b/clang/lib/Format/Format.cpp @@ -272,8 +272,7 @@ public: WhitespaceManager &Whitespaces, bool StructuralError) : Style(Style), SourceMgr(SourceMgr), Line(Line), FirstIndent(FirstIndent), RootToken(RootToken), - Whitespaces(Whitespaces), Count(0) { - } + Whitespaces(Whitespaces), Count(0) {} /// \brief Formats an \c UnwrappedLine. /// @@ -332,8 +331,7 @@ private: BreakBeforeClosingBrace(false), QuestionColumn(0), AvoidBinPacking(AvoidBinPacking), BreakBeforeParameter(false), HasMultiParameterLine(HasMultiParameterLine), ColonPos(0), - BreakBeforeThirdOperand(false) { - } + BreakBeforeThirdOperand(false) {} /// \brief The position to which a specific parenthesis level needs to be /// indented. @@ -766,8 +764,7 @@ private: /// inserting a newline dependent on the \c NewLine. struct StateNode { StateNode(const LineState &State, bool NewLine, StateNode *Previous) - : State(State), NewLine(NewLine), Previous(Previous) { - } + : State(State), NewLine(NewLine), Previous(Previous) {} LineState State; bool NewLine; StateNode *Previous; @@ -1038,8 +1035,7 @@ public: SourceManager &SourceMgr, const std::vector &Ranges) : Diag(Diag), Style(Style), Lex(Lex), SourceMgr(SourceMgr), - Whitespaces(SourceMgr), Ranges(Ranges) { - } + Whitespaces(SourceMgr), Ranges(Ranges) {} virtual ~Formatter() {} @@ -1199,18 +1195,14 @@ private: void tryFitMultipleLinesInOne(unsigned Indent, std::vector::iterator &I, std::vector::iterator E) { - unsigned Limit = Style.ColumnLimit - (I->InPPDirective ? 1 : 0) - Indent; - // We can never merge stuff if there are trailing line comments. if (I->Last->Type == TT_LineComment) return; - // Check whether the UnwrappedLine can be put onto a single line. If - // so, this is bound to be the optimal solution (by definition) and we - // don't need to analyze the entire solution space. - if (I->Last->TotalLength > Limit) - return; - Limit -= I->Last->TotalLength; + unsigned Limit = Style.ColumnLimit - (I->InPPDirective ? 1 : 0) - Indent; + // If we already exceed the column limit, we set 'Limit' to 0. The different + // tryMerge..() functions can then decide whether to still do merging. + Limit = I->Last->TotalLength > Limit ? 0 : Limit - I->Last->TotalLength; if (I + 1 == E || (I + 1)->Type == LT_Invalid) return; @@ -1229,6 +1221,8 @@ private: void tryMergeSimplePPDirective(std::vector::iterator &I, std::vector::iterator E, unsigned Limit) { + if (Limit == 0) + return; AnnotatedLine &Line = *I; if (!(I + 1)->InPPDirective || (I + 1)->First.FormatTok.HasUnescapedNewline) return; @@ -1243,6 +1237,8 @@ private: void tryMergeSimpleIf(std::vector::iterator &I, std::vector::iterator E, unsigned Limit) { + if (Limit == 0) + return; if (!Style.AllowShortIfStatementsOnASingleLine) return; if ((I + 1)->InPPDirective != I->InPPDirective || @@ -1282,11 +1278,13 @@ private: AnnotatedToken *Tok = &(I + 1)->First; if (Tok->Children.empty() && Tok->is(tok::r_brace) && - !Tok->MustBreakBefore && Tok->TotalLength <= Limit) { + !Tok->MustBreakBefore) { + // We merge empty blocks even if the line exceeds the column limit. Tok->SpacesRequiredBefore = 0; + Tok->CanBreakBefore = true; join(Line, *(I + 1)); I += 1; - } else { + } else if (Limit != 0) { // Check that we still have three lines and they fit into the limit. if (I + 2 == E || (I + 2)->Type == LT_Invalid || !nextTwoLinesFitInto(I, Limit)) @@ -1321,9 +1319,11 @@ private: } void join(AnnotatedLine &A, const AnnotatedLine &B) { + unsigned LengthA = A.Last->TotalLength + B.First.SpacesRequiredBefore; A.Last->Children.push_back(B.First); while (!A.Last->Children.empty()) { A.Last->Children[0].Parent = A.Last; + A.Last->Children[0].TotalLength += LengthA; A.Last = &A.Last->Children[0]; } } diff --git a/clang/lib/Format/TokenAnnotator.cpp b/clang/lib/Format/TokenAnnotator.cpp index dcbdb786fae..af59a18e96b 100644 --- a/clang/lib/Format/TokenAnnotator.cpp +++ b/clang/lib/Format/TokenAnnotator.cpp @@ -517,8 +517,7 @@ private: : BindingStrength(BindingStrength), LongestObjCSelectorName(0), ColonIsForRangeExpr(false), ColonIsObjCMethodExpr(false), FirstObjCSelectorName(NULL), IsExpression(IsExpression), - LookForFunctionName(false) { - } + LookForFunctionName(false) {} unsigned BindingStrength; unsigned LongestObjCSelectorName; @@ -1104,6 +1103,7 @@ bool TokenAnnotator::canBreakBefore(const AnnotatedLine &Line, Right.is(tok::arrow) || Right.is(tok::period) || Right.is(tok::colon) || Left.is(tok::coloncolon) || Left.is(tok::semi) || Left.is(tok::l_brace) || + Right.is(tok::r_brace) || (Left.is(tok::r_paren) && Left.Type != TT_CastRParen && Right.is(tok::identifier)) || (Left.is(tok::l_paren) && !Right.is(tok::r_paren)) || -- cgit v1.2.3