diff options
Diffstat (limited to 'clang/lib/Format')
| -rw-r--r-- | clang/lib/Format/TokenAnnotator.cpp | 16 | ||||
| -rw-r--r-- | clang/lib/Format/TokenAnnotator.h | 3 | 
2 files changed, 13 insertions, 6 deletions
| diff --git a/clang/lib/Format/TokenAnnotator.cpp b/clang/lib/Format/TokenAnnotator.cpp index f18627ef581..757d3012b63 100644 --- a/clang/lib/Format/TokenAnnotator.cpp +++ b/clang/lib/Format/TokenAnnotator.cpp @@ -1056,6 +1056,7 @@ void TokenAnnotator::calculateFormattingInformation(AnnotatedLine &Line) {    if (!Line.First->Next)      return;    FormatToken *Current = Line.First->Next; +  bool InFunctionDecl = Line.MightBeFunctionDecl;    while (Current != NULL) {      if (Current->Type == TT_LineComment)        Current->SpacesRequiredBefore = Style.SpacesBeforeTrailingComments; @@ -1075,11 +1076,15 @@ void TokenAnnotator::calculateFormattingInformation(AnnotatedLine &Line) {        Current->TotalLength = Current->Previous->TotalLength +                               Current->ColumnWidth +                               Current->SpacesRequiredBefore; + +    if (Current->Type == TT_CtorInitializerColon) +      InFunctionDecl = false; +      // FIXME: Only calculate this if CanBreakBefore is true once static      // initializers etc. are sorted out.      // FIXME: Move magic numbers to a better place. -    Current->SplitPenalty = -        20 * Current->BindingStrength + splitPenalty(Line, *Current); +    Current->SplitPenalty = 20 * Current->BindingStrength + +                            splitPenalty(Line, *Current, InFunctionDecl);      Current = Current->Next;    } @@ -1116,7 +1121,8 @@ void TokenAnnotator::calculateUnbreakableTailLengths(AnnotatedLine &Line) {  }  unsigned TokenAnnotator::splitPenalty(const AnnotatedLine &Line, -                                      const FormatToken &Tok) { +                                      const FormatToken &Tok, +                                      bool InFunctionDecl) {    const FormatToken &Left = *Tok.Previous;    const FormatToken &Right = Tok; @@ -1132,7 +1138,7 @@ unsigned TokenAnnotator::splitPenalty(const AnnotatedLine &Line,        return 3;      if (Left.Type == TT_StartOfName)        return 20; -    if (Line.MightBeFunctionDecl && Right.BindingStrength == 1) +    if (InFunctionDecl && Right.BindingStrength == 1)        // FIXME: Clean up hack of using BindingStrength to find top-level names.        return Style.PenaltyReturnTypeOnItsOwnLine;      return 200; @@ -1174,7 +1180,7 @@ unsigned TokenAnnotator::splitPenalty(const AnnotatedLine &Line,    if (Left.is(tok::colon) && Left.Type == TT_ObjCMethodExpr)      return 20; -  if (Left.is(tok::l_paren) && Line.MightBeFunctionDecl) +  if (Left.is(tok::l_paren) && InFunctionDecl)      return 100;    if (Left.opensScope())      return Left.ParameterCount > 1 ? Style.PenaltyBreakBeforeFirstCallParameter diff --git a/clang/lib/Format/TokenAnnotator.h b/clang/lib/Format/TokenAnnotator.h index ca8b1154157..aa49b2a5c07 100644 --- a/clang/lib/Format/TokenAnnotator.h +++ b/clang/lib/Format/TokenAnnotator.h @@ -110,7 +110,8 @@ public:  private:    /// \brief Calculate the penalty for splitting before \c Tok. -  unsigned splitPenalty(const AnnotatedLine &Line, const FormatToken &Tok); +  unsigned splitPenalty(const AnnotatedLine &Line, const FormatToken &Tok, +                        bool InFunctionDecl);    bool spaceRequiredBetween(const AnnotatedLine &Line, const FormatToken &Left,                              const FormatToken &Right); | 

