diff options
| author | Daniel Jasper <djasper@google.com> | 2013-04-08 10:36:32 +0000 | 
|---|---|---|
| committer | Daniel Jasper <djasper@google.com> | 2013-04-08 10:36:32 +0000 | 
| commit | bd16eea59f3487fa02c65f43d5a3b72eff3ab5d9 (patch) | |
| tree | 4be2752c5b3ef0400bb8f0fea8112a6e31caecdb /clang/lib | |
| parent | a6d5e3e9a27d24341746337ac9b47b05327c08e0 (diff) | |
| download | bcm5719-llvm-bd16eea59f3487fa02c65f43d5a3b72eff3ab5d9.tar.gz bcm5719-llvm-bd16eea59f3487fa02c65f43d5a3b72eff3ab5d9.zip | |
x
llvm-svn: 179015
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Format/Format.cpp | 26 | ||||
| -rw-r--r-- | clang/lib/Format/TokenAnnotator.cpp | 35 | ||||
| -rw-r--r-- | clang/lib/Format/TokenAnnotator.h | 9 | 
3 files changed, 43 insertions, 27 deletions
| diff --git a/clang/lib/Format/Format.cpp b/clang/lib/Format/Format.cpp index 101b16f1a18..8cdcd0b0289 100644 --- a/clang/lib/Format/Format.cpp +++ b/clang/lib/Format/Format.cpp @@ -86,12 +86,6 @@ static bool isTrailingComment(const AnnotatedToken &Tok) {           (Tok.Children.empty() || Tok.Children[0].MustBreakBefore);  } -static bool isComparison(const AnnotatedToken &Tok) { -  prec::Level Precedence = getPrecedence(Tok); -  return Tok.Type == TT_BinaryOperator && -         (Precedence == prec::Equality || Precedence == prec::Relational); -} -  // Returns the length of everything up to the first possible line break after  // the ), ], } or > matching \c Tok.  static unsigned getLengthToMatchingParen(const AnnotatedToken &Tok) { @@ -492,10 +486,6 @@ public:      State.StartOfStringLiteral = 0;      State.StartOfLineLevel = State.ParenLevel; -    DEBUG({ -      DebugTokenState(*State.NextToken); -    }); -      // The first token has already been indented and thus consumed.      moveStateToNextToken(State, /*DryRun=*/ false); @@ -741,8 +731,7 @@ private:            State.Stack.back().ColonPos =                State.Column + Current.FormatTok.TokenLength;          } -      } else if (Current.Type == TT_StartOfName || Current.is(tok::question) || -                 Previous.is(tok::equal) || isComparison(Previous) || +      } else if (Current.Type == TT_StartOfName || Previous.is(tok::equal) ||                   Previous.Type == TT_ObjCMethodExpr) {          State.Column = ContinuationIndent;        } else { @@ -879,10 +868,13 @@ private:        State.Stack.back().StartOfFunctionCall =            Current.LastInChainOfCalls ? 0 : State.Column;      if (Current.Type == TT_CtorInitializerColon) { +      State.Stack.back().Indent = State.Column + 2;        if (Style.ConstructorInitializerAllOnOneLineOrOnePerLine)          State.Stack.back().AvoidBinPacking = true;        State.Stack.back().BreakBeforeParameter = false;      } +    if (Current.is(tok::kw_return)) +      State.Stack.back().LastSpace = State.Column + 7;      // In ObjC method declaration we align on the ":" of parameters, but we need      // to ensure that we indent parameters on subsequent lines by at least 4. @@ -890,9 +882,15 @@ private:        State.Stack.back().Indent += 4;      // Insert scopes created by fake parenthesis. -    for (unsigned i = 0, e = Current.FakeLParens; i != e; ++i) { +    for (SmallVector<unsigned, 4>::const_reverse_iterator +             I = Current.FakeLParens.rbegin(), +             E = Current.FakeLParens.rend(); +         I != E; ++I) {        ParenState NewParenState = State.Stack.back(); -      NewParenState.Indent = std::max(State.Column, State.Stack.back().Indent); +      NewParenState.Indent = //State.Stack.back().LastSpace; +          std::max(State.Column, State.Stack.back().LastSpace); +      if ((*I > 3 && State.ParenLevel != 0) || *I == 4) +        NewParenState.Indent += 4;        NewParenState.BreakBeforeParameter = false;        State.Stack.push_back(NewParenState);      } diff --git a/clang/lib/Format/TokenAnnotator.cpp b/clang/lib/Format/TokenAnnotator.cpp index 44421c4bbec..833a0c062bc 100644 --- a/clang/lib/Format/TokenAnnotator.cpp +++ b/clang/lib/Format/TokenAnnotator.cpp @@ -16,6 +16,7 @@  #include "TokenAnnotator.h"  #include "clang/Basic/SourceManager.h"  #include "clang/Lex/Lexer.h" +#include "llvm/Support/Debug.h"  namespace clang {  namespace format { @@ -782,12 +783,9 @@ public:      if (Precedence > prec::PointerToMember || Current == NULL)        return; -    // Skip over "return" until we can properly parse it. -    if (Current->is(tok::kw_return)) -      next(); -      // Eagerly consume trailing comments. -    while (isTrailingComment(Current)) { +    while (Current && Current->FormatTok.NewlinesBefore == 0 && +           isTrailingComment(Current)) {        next();      } @@ -802,8 +800,7 @@ public:        if (Current) {          if (Current->Type == TT_ConditionalExpr)            CurrentPrecedence = 1 + (int) prec::Conditional; -        else if (Current->is(tok::semi) || Current->Type == TT_InlineASMColon || -                 Current->Type == TT_CtorInitializerColon) +        else if (Current->is(tok::semi) || Current->Type == TT_InlineASMColon)            CurrentPrecedence = 1;          else if (Current->Type == TT_BinaryOperator || Current->is(tok::comma))            CurrentPrecedence = 1 + (int) getPrecedence(*Current); @@ -814,7 +811,7 @@ public:        if (Current == NULL || closesScope(*Current) ||            (CurrentPrecedence != 0 && CurrentPrecedence < Precedence)) {          if (OperatorFound) { -          ++Start->FakeLParens; +          Start->FakeLParens.push_back(Precedence);            if (Current)              ++Current->Parent->FakeRParens;          } @@ -829,9 +826,9 @@ public:            parse();          }          // Remove fake parens that just duplicate the real parens. -        if (Current && Left->Children[0].FakeLParens > 0 && +        if (Current && !Left->Children[0].FakeLParens.empty() &&              Current->Parent->FakeRParens > 0) { -          --Left->Children[0].FakeLParens; +          Left->Children[0].FakeLParens.pop_back();            --Current->Parent->FakeRParens;          }          next(); @@ -863,6 +860,10 @@ void TokenAnnotator::annotate(AnnotatedLine &Line) {    ExpressionParser ExprParser(Line);    ExprParser.parse(); +  DEBUG({ +    printDebugInfo(Line); +  }); +    if (Line.First.Type == TT_ObjCMethodSpecifier)      Line.Type = LT_ObjCMethodDecl;    else if (Line.First.Type == TT_ObjCDecl) @@ -1187,5 +1188,19 @@ bool TokenAnnotator::canBreakBefore(const AnnotatedLine &Line,           (Left.is(tok::l_square) && !Right.is(tok::r_square));  } +void TokenAnnotator::printDebugInfo(const AnnotatedLine &Line) { +  llvm::errs() << "AnnotatedTokens:\n"; +  const AnnotatedToken *Tok = &Line.First; +  while (Tok) { +    llvm::errs() << Tok->FormatTok.Tok.getName() << ":" +                 << " Type=" << Tok->Type << " FakeLParens="; +    for (unsigned i = 0, e = Tok->FakeLParens.size(); i != e; ++i) +      llvm::errs() << Tok->FakeLParens[i] << "/"; +    llvm::errs() << " FakeRParens=" << Tok->FakeRParens << "\n"; +    Tok = Tok->Children.empty() ? NULL : &Tok->Children[0]; +  } +  llvm::errs() << "----\n"; +} +  } // namespace format  } // namespace clang diff --git a/clang/lib/Format/TokenAnnotator.h b/clang/lib/Format/TokenAnnotator.h index c41ee33c439..605f5067939 100644 --- a/clang/lib/Format/TokenAnnotator.h +++ b/clang/lib/Format/TokenAnnotator.h @@ -75,7 +75,7 @@ public:          CanBreakBefore(false), MustBreakBefore(false),          ClosesTemplateDeclaration(false), MatchingParen(NULL),          ParameterCount(0), BindingStrength(0), SplitPenalty(0), -        LongestObjCSelectorName(0), Parent(NULL), FakeLParens(0), +        LongestObjCSelectorName(0), Parent(NULL),          FakeRParens(0), LastInChainOfCalls(false),          PartOfMultiVariableDeclStmt(false) {} @@ -158,8 +158,9 @@ public:    std::vector<AnnotatedToken> Children;    AnnotatedToken *Parent; -  /// \brief Insert this many fake ( before this token for correct indentation. -  unsigned FakeLParens; +  /// \brief Stores the number of required fake parenthesis and the +  /// corresponding operator precedence. +  SmallVector<unsigned, 4>  FakeLParens;    /// \brief Insert this many fake ) after this token for correct indentation.    unsigned FakeRParens; @@ -248,6 +249,8 @@ private:    bool canBreakBefore(const AnnotatedLine &Line, const AnnotatedToken &Right); +  void printDebugInfo(const AnnotatedLine &Line); +    const FormatStyle &Style;    SourceManager &SourceMgr;    Lexer &Lex; | 

