diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2015-06-09 19:08:19 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2015-06-09 19:08:19 +0000 | 
| commit | 798321d8eb5630cd4a8f490a4f25e32ef195fb07 (patch) | |
| tree | a59f5569ef36d00388c0428426abef26aa9105b6 /lib/Format | |
| parent | 5e20cdd81c44a443562a09007668ffdf76c455af (diff) | |
Diffstat (limited to 'lib/Format')
| -rw-r--r-- | lib/Format/BreakableToken.cpp | 4 | ||||
| -rw-r--r-- | lib/Format/ContinuationIndenter.cpp | 19 | ||||
| -rw-r--r-- | lib/Format/ContinuationIndenter.h | 6 | ||||
| -rw-r--r-- | lib/Format/Format.cpp | 2 | ||||
| -rw-r--r-- | lib/Format/FormatToken.h | 1 | ||||
| -rw-r--r-- | lib/Format/TokenAnnotator.cpp | 93 | ||||
| -rw-r--r-- | lib/Format/UnwrappedLineParser.cpp | 51 | ||||
| -rw-r--r-- | lib/Format/UnwrappedLineParser.h | 5 | ||||
| -rw-r--r-- | lib/Format/WhitespaceManager.cpp | 12 | 
9 files changed, 95 insertions, 98 deletions
| diff --git a/lib/Format/BreakableToken.cpp b/lib/Format/BreakableToken.cpp index 66e935abdf55..e3e162d070f8 100644 --- a/lib/Format/BreakableToken.cpp +++ b/lib/Format/BreakableToken.cpp @@ -183,7 +183,7 @@ void BreakableStringLiteral::insertBreak(unsigned LineIndex,  }  static StringRef getLineCommentIndentPrefix(StringRef Comment) { -  static const char *const KnownPrefixes[] = { "///", "//" }; +  static const char *const KnownPrefixes[] = { "///", "//", "//!" };    StringRef LongestPrefix;    for (StringRef KnownPrefix : KnownPrefixes) {      if (Comment.startswith(KnownPrefix)) { @@ -210,6 +210,8 @@ BreakableLineComment::BreakableLineComment(        Prefix = "// ";      else if (Prefix == "///")        Prefix = "/// "; +    else if (Prefix == "//!") +      Prefix = "//! ";    }  } diff --git a/lib/Format/ContinuationIndenter.cpp b/lib/Format/ContinuationIndenter.cpp index 4e8f5af263d2..91bc64b2b8b4 100644 --- a/lib/Format/ContinuationIndenter.cpp +++ b/lib/Format/ContinuationIndenter.cpp @@ -159,7 +159,8 @@ bool ContinuationIndenter::mustBreak(const LineState &State) {    if (((Previous.is(TT_DictLiteral) && Previous.is(tok::l_brace)) ||         Previous.is(TT_ArrayInitializerLSquare)) &&        Style.ColumnLimit > 0 && -      getLengthToMatchingParen(Previous) + State.Column > getColumnLimit(State)) +      getLengthToMatchingParen(Previous) + State.Column - 1 > +          getColumnLimit(State))      return true;    if (Current.is(TT_CtorInitializerColon) &&        ((Style.AllowShortFunctionsOnASingleLine != FormatStyle::SFS_All) || @@ -328,7 +329,7 @@ void ContinuationIndenter::addTokenOnCurrentLine(LineState &State, bool DryRun,        State.Column > getNewLineColumn(State))      State.Stack.back().ContainsUnwrappedBuilder = true; -  if (Current.is(TT_LambdaArrow)) +  if (Current.is(TT_LambdaArrow) && Style.Language == FormatStyle::LK_Java)      State.Stack.back().NoLineBreak = true;    if (Current.isMemberAccess() && Previous.is(tok::r_paren) &&        (Previous.MatchingParen && @@ -462,6 +463,8 @@ unsigned ContinuationIndenter::addTokenOnNewLine(LineState &State,    if (NextNonComment->is(tok::question) ||        (PreviousNonComment && PreviousNonComment->is(tok::question)))      State.Stack.back().BreakBeforeParameter = true; +  if (Current.is(TT_BinaryOperator) && Current.CanBreakBefore) +    State.Stack.back().BreakBeforeParameter = false;    if (!DryRun) {      unsigned Newlines = std::max( @@ -481,11 +484,9 @@ unsigned ContinuationIndenter::addTokenOnNewLine(LineState &State,    bool NestedBlockSpecialCase =        Current.is(tok::r_brace) && State.Stack.size() > 1 &&        State.Stack[State.Stack.size() - 2].NestedBlockInlined; -  if (!NestedBlockSpecialCase) { -    for (unsigned i = 0, e = State.Stack.size() - 1; i != e; ++i) { +  if (!NestedBlockSpecialCase) +    for (unsigned i = 0, e = State.Stack.size() - 1; i != e; ++i)        State.Stack[i].BreakBeforeParameter = true; -    } -  }    if (PreviousNonComment &&        !PreviousNonComment->isOneOf(tok::comma, tok::semi) && @@ -689,11 +690,9 @@ unsigned ContinuationIndenter::moveStateToNextToken(LineState &State,    //   }, a, b, c);    if (Current.isNot(tok::comment) && Previous && Previous->is(tok::l_brace) &&        State.Stack.size() > 1) { -    if (State.Stack[State.Stack.size() - 2].NestedBlockInlined && Newline) { -      for (unsigned i = 0, e = State.Stack.size() - 1; i != e; ++i) { +    if (State.Stack[State.Stack.size() - 2].NestedBlockInlined && Newline) +      for (unsigned i = 0, e = State.Stack.size() - 1; i != e; ++i)          State.Stack[i].NoLineBreak = true; -      } -    }      State.Stack[State.Stack.size() - 2].NestedBlockInlined = false;    }    if (Previous && (Previous->isOneOf(tok::l_paren, tok::comma, tok::colon) || diff --git a/lib/Format/ContinuationIndenter.h b/lib/Format/ContinuationIndenter.h index 36691d945b4f..1da6bd95f100 100644 --- a/lib/Format/ContinuationIndenter.h +++ b/lib/Format/ContinuationIndenter.h @@ -297,11 +297,11 @@ struct ParenState {      if (VariablePos != Other.VariablePos)        return VariablePos < Other.VariablePos;      if (ContainsLineBreak != Other.ContainsLineBreak) -      return ContainsLineBreak < Other.ContainsLineBreak; +      return ContainsLineBreak;      if (ContainsUnwrappedBuilder != Other.ContainsUnwrappedBuilder) -      return ContainsUnwrappedBuilder < Other.ContainsUnwrappedBuilder; +      return ContainsUnwrappedBuilder;      if (NestedBlockInlined != Other.NestedBlockInlined) -      return NestedBlockInlined < Other.NestedBlockInlined; +      return NestedBlockInlined;      return false;    }  }; diff --git a/lib/Format/Format.cpp b/lib/Format/Format.cpp index 10c68f9da617..c725b4bf30ab 100644 --- a/lib/Format/Format.cpp +++ b/lib/Format/Format.cpp @@ -1640,8 +1640,6 @@ FormatStyle getStyle(StringRef StyleName, StringRef FileName,        return Style;      }    } -  llvm::errs() << "Can't find usable .clang-format, using " << FallbackStyle -               << " style\n";    if (!UnsuitableConfigFiles.empty()) {      llvm::errs() << "Configuration file(s) do(es) not support "                   << getLanguageName(Style.Language) << ": " diff --git a/lib/Format/FormatToken.h b/lib/Format/FormatToken.h index ec0fdf4aa813..dd12969454e4 100644 --- a/lib/Format/FormatToken.h +++ b/lib/Format/FormatToken.h @@ -51,6 +51,7 @@ enum TokenType {    TT_InlineASMBrace,    TT_InlineASMColon,    TT_JavaAnnotation, +  TT_JsComputedPropertyName,    TT_JsFatArrow,    TT_JsTypeColon,    TT_JsTypeOptionalQuestion, diff --git a/lib/Format/TokenAnnotator.cpp b/lib/Format/TokenAnnotator.cpp index 98f5709b9062..78e6103bfcd5 100644 --- a/lib/Format/TokenAnnotator.cpp +++ b/lib/Format/TokenAnnotator.cpp @@ -260,6 +260,7 @@ private:      Left->ParentBracket = Contexts.back().ContextKind;      FormatToken *Parent = Left->getPreviousNonComment();      bool StartsObjCMethodExpr = +        Style.Language == FormatStyle::LK_Cpp &&          Contexts.back().CanBeExpression && Left->isNot(TT_LambdaLSquare) &&          CurrentToken->isNot(tok::l_brace) &&          (!Parent || @@ -268,19 +269,31 @@ private:           Parent->isUnaryOperator() ||           Parent->isOneOf(TT_ObjCForIn, TT_CastRParen) ||           getBinOpPrecedence(Parent->Tok.getKind(), true, true) > prec::Unknown); -    ScopedContextCreator ContextCreator(*this, tok::l_square, 10); -    Contexts.back().IsExpression = true;      bool ColonFound = false; -    if (StartsObjCMethodExpr) { -      Contexts.back().ColonIsObjCMethodExpr = true; -      Left->Type = TT_ObjCMethodExpr; -    } else if (Parent && Parent->is(tok::at)) { -      Left->Type = TT_ArrayInitializerLSquare; -    } else if (Left->is(TT_Unknown)) { -      Left->Type = TT_ArraySubscriptLSquare; +    unsigned BindingIncrease = 1; +    if (Left->is(TT_Unknown)) { +      if (StartsObjCMethodExpr) { +        Left->Type = TT_ObjCMethodExpr; +      } else if (Style.Language == FormatStyle::LK_JavaScript && Parent && +                 Contexts.back().ContextKind == tok::l_brace && +                 Parent->isOneOf(tok::l_brace, tok::comma)) { +        Left->Type = TT_JsComputedPropertyName; +      } else if (Parent && +                 Parent->isOneOf(tok::at, tok::equal, tok::comma, tok::l_paren, +                                 tok::l_square, tok::question, tok::colon, +                                 tok::kw_return)) { +        Left->Type = TT_ArrayInitializerLSquare; +      } else { +        BindingIncrease = 10; +        Left->Type = TT_ArraySubscriptLSquare; +      }      } +    ScopedContextCreator ContextCreator(*this, tok::l_square, BindingIncrease); +    Contexts.back().IsExpression = true; +    Contexts.back().ColonIsObjCMethodExpr = StartsObjCMethodExpr; +      while (CurrentToken) {        if (CurrentToken->is(tok::r_square)) {          if (CurrentToken->Next && CurrentToken->Next->is(tok::l_paren) && @@ -321,10 +334,8 @@ private:          }          ColonFound = true;        } -      if (CurrentToken->is(tok::comma) && -          Style.Language != FormatStyle::LK_Proto && -          (Left->is(TT_ArraySubscriptLSquare) || -           (Left->is(TT_ObjCMethodExpr) && !ColonFound))) +      if (CurrentToken->is(tok::comma) && Left->is(TT_ObjCMethodExpr) && +          !ColonFound)          Left->Type = TT_ArrayInitializerLSquare;        FormatToken *Tok = CurrentToken;        if (!consumeToken()) @@ -437,7 +448,8 @@ private:               !Line.First->isOneOf(tok::kw_enum, tok::kw_case)) ||              Contexts.back().ContextKind == tok::l_paren ||  // function params              Contexts.back().ContextKind == tok::l_square || // array type -            Line.MustBeDeclaration) { // method/property declaration +            (Contexts.size() == 1 && +             Line.MustBeDeclaration)) { // method/property declaration            Tok->Type = TT_JsTypeColon;            break;          } @@ -742,8 +754,8 @@ private:      // recovered from an error (e.g. failure to find the matching >).      if (!CurrentToken->isOneOf(TT_LambdaLSquare, TT_ForEachMacro,                                 TT_FunctionLBrace, TT_ImplicitStringLiteral, -                               TT_InlineASMBrace, TT_RegexLiteral, -                               TT_TrailingReturnArrow)) +                               TT_InlineASMBrace, TT_JsFatArrow, TT_LambdaArrow, +                               TT_RegexLiteral))        CurrentToken->Type = TT_Unknown;      CurrentToken->Role.reset();      CurrentToken->MatchingParen = nullptr; @@ -832,6 +844,8 @@ private:        Contexts.back().IsExpression = true;      } else if (Current.is(TT_TrailingReturnArrow)) {        Contexts.back().IsExpression = false; +    } else if (Current.is(TT_LambdaArrow)) { +      Contexts.back().IsExpression = Style.Language == FormatStyle::LK_Java;      } else if (Current.is(tok::l_paren) && !Line.MustBeDeclaration &&                 !Line.InPPDirective &&                 (!Current.Previous || @@ -1308,25 +1322,27 @@ private:        const FormatToken *NextNonComment = Current->getNextNonComment();        if (Current->is(TT_ConditionalExpr))          return prec::Conditional; -      else if (NextNonComment && NextNonComment->is(tok::colon) && -               NextNonComment->is(TT_DictLiteral)) +      if (NextNonComment && NextNonComment->is(tok::colon) && +          NextNonComment->is(TT_DictLiteral))          return prec::Comma; -      else if (Current->is(TT_LambdaArrow)) +      if (Current->is(TT_LambdaArrow))          return prec::Comma; -      else if (Current->isOneOf(tok::semi, TT_InlineASMColon, -                                TT_SelectorName) || -               (Current->is(tok::comment) && NextNonComment && -                NextNonComment->is(TT_SelectorName))) +      if (Current->is(TT_JsFatArrow)) +        return prec::Assignment; +      if (Current->isOneOf(tok::semi, TT_InlineASMColon, TT_SelectorName, +                           TT_JsComputedPropertyName) || +          (Current->is(tok::comment) && NextNonComment && +           NextNonComment->is(TT_SelectorName)))          return 0; -      else if (Current->is(TT_RangeBasedForLoopColon)) +      if (Current->is(TT_RangeBasedForLoopColon))          return prec::Comma; -      else if (Current->is(TT_BinaryOperator) || Current->is(tok::comma)) +      if (Current->is(TT_BinaryOperator) || Current->is(tok::comma))          return Current->getPrecedence(); -      else if (Current->isOneOf(tok::period, tok::arrow)) +      if (Current->isOneOf(tok::period, tok::arrow))          return PrecedenceArrowAndPeriod; -      else if (Style.Language == FormatStyle::LK_Java && -               Current->isOneOf(Keywords.kw_extends, Keywords.kw_implements, -                                Keywords.kw_throws)) +      if (Style.Language == FormatStyle::LK_Java && +          Current->isOneOf(Keywords.kw_extends, Keywords.kw_implements, +                           Keywords.kw_throws))          return 0;      }      return -1; @@ -1615,7 +1631,8 @@ unsigned TokenAnnotator::splitPenalty(const AnnotatedLine &Line,      // Slightly prefer formatting local lambda definitions like functions.      if (Right.is(TT_LambdaLSquare) && Left.is(tok::equal))        return 50; -    if (!Right.isOneOf(TT_ObjCMethodExpr, TT_LambdaLSquare)) +    if (!Right.isOneOf(TT_ObjCMethodExpr, TT_LambdaLSquare, +                       TT_ArrayInitializerLSquare))        return 500;    } @@ -1631,7 +1648,7 @@ unsigned TokenAnnotator::splitPenalty(const AnnotatedLine &Line,    }    if (Right.is(TT_PointerOrReference))      return 190; -  if (Right.is(TT_TrailingReturnArrow)) +  if (Right.is(TT_LambdaArrow))      return 110;    if (Left.is(tok::equal) && Right.is(tok::l_brace))      return 150; @@ -1867,7 +1884,7 @@ bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,          Left.isOneOf(Keywords.kw_returns, Keywords.kw_option))        return true;    } else if (Style.Language == FormatStyle::LK_JavaScript) { -    if (Left.is(Keywords.kw_var)) +    if (Left.isOneOf(Keywords.kw_var, TT_JsFatArrow))        return true;      if (Right.isOneOf(TT_JsTypeColon, TT_JsTypeOptionalQuestion))        return false; @@ -1886,8 +1903,6 @@ bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,    } else if (Style.Language == FormatStyle::LK_Java) {      if (Left.is(tok::r_square) && Right.is(tok::l_brace))        return true; -    if (Left.is(TT_LambdaArrow) || Right.is(TT_LambdaArrow)) -      return true;      if (Left.is(Keywords.kw_synchronized) && Right.is(tok::l_paren))        return Style.SpaceBeforeParens != FormatStyle::SBPO_Never;      if ((Left.isOneOf(tok::kw_static, tok::kw_public, tok::kw_private, @@ -1912,7 +1927,8 @@ bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,        (Right.is(tok::equal) || Left.is(tok::equal)))      return false; -  if (Right.is(TT_TrailingReturnArrow) || Left.is(TT_TrailingReturnArrow)) +  if (Right.isOneOf(TT_TrailingReturnArrow, TT_LambdaArrow) || +      Left.isOneOf(TT_TrailingReturnArrow, TT_LambdaArrow))      return true;    if (Left.is(tok::comma))      return true; @@ -1947,10 +1963,9 @@ bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,      return Style.SpaceAfterCStyleCast ||             Right.isOneOf(TT_BinaryOperator, TT_SelectorName); -  if (Left.is(tok::greater) && Right.is(tok::greater)) { +  if (Left.is(tok::greater) && Right.is(tok::greater))      return Right.is(TT_TemplateCloser) && Left.is(TT_TemplateCloser) &&             (Style.Standard != FormatStyle::LS_Cpp11 || Style.SpacesInAngles); -  }    if (Right.isOneOf(tok::arrow, tok::period, tok::arrowstar, tok::periodstar) ||        Left.isOneOf(tok::arrow, tok::period, tok::arrowstar, tok::periodstar))      return false; @@ -2094,6 +2109,7 @@ bool TokenAnnotator::canBreakBefore(const AnnotatedLine &Line,                                      const FormatToken &Right) {    const FormatToken &Left = *Right.Previous; +  // Language-specific stuff.    if (Style.Language == FormatStyle::LK_Java) {      if (Left.isOneOf(Keywords.kw_throws, Keywords.kw_extends,                       Keywords.kw_implements)) @@ -2101,6 +2117,9 @@ bool TokenAnnotator::canBreakBefore(const AnnotatedLine &Line,      if (Right.isOneOf(Keywords.kw_throws, Keywords.kw_extends,                        Keywords.kw_implements))        return true; +  } else if (Style.Language == FormatStyle::LK_JavaScript) { +    if (Left.is(TT_JsFatArrow) && Right.is(tok::l_brace)) +      return false;    }    if (Left.is(tok::at)) diff --git a/lib/Format/UnwrappedLineParser.cpp b/lib/Format/UnwrappedLineParser.cpp index 939528fbffe5..6ad43294ca97 100644 --- a/lib/Format/UnwrappedLineParser.cpp +++ b/lib/Format/UnwrappedLineParser.cpp @@ -887,9 +887,8 @@ void UnwrappedLineParser::parseStructuralElement() {        // followed by a curly.        if (FormatTok->is(TT_JsFatArrow)) {          nextToken(); -        if (FormatTok->is(tok::l_brace)) { +        if (FormatTok->is(tok::l_brace))            parseChildBlock(); -        }          break;        } @@ -912,6 +911,10 @@ void UnwrappedLineParser::parseStructuralElement() {  }  bool UnwrappedLineParser::tryToParseLambda() { +  if (Style.Language != FormatStyle::LK_Cpp) { +    nextToken(); +    return false; +  }    // FIXME: This is a dirty way to access the previous token. Find a better    // solution.    if (!Line->Tokens.empty() && @@ -950,7 +953,7 @@ bool UnwrappedLineParser::tryToParseLambda() {        nextToken();        break;      case tok::arrow: -      FormatTok->Type = TT_TrailingReturnArrow; +      FormatTok->Type = TT_LambdaArrow;        nextToken();        break;      default: @@ -1019,7 +1022,7 @@ void UnwrappedLineParser::tryToParseJSFunction() {      return;    // Parse formal parameter list. -  parseBalanced(tok::l_paren, tok::r_paren); +  parseParens();    if (FormatTok->is(tok::colon)) {      // Parse a type definition. @@ -1027,34 +1030,16 @@ void UnwrappedLineParser::tryToParseJSFunction() {      // Eat the type declaration. For braced inline object types, balance braces,      // otherwise just parse until finding an l_brace for the function body. -    if (FormatTok->is(tok::l_brace)) { -      parseBalanced(tok::l_brace, tok::r_brace); -    } else { -      while(FormatTok->isNot(tok::l_brace) && !eof()) { +    if (FormatTok->is(tok::l_brace)) +      tryToParseBracedList(); +    else +      while(FormatTok->isNot(tok::l_brace) && !eof())          nextToken(); -      } -    }    }    parseChildBlock();  } -void UnwrappedLineParser::parseBalanced(tok::TokenKind OpenKind, -                                        tok::TokenKind CloseKind) { -  assert(FormatTok->is(OpenKind)); -  nextToken(); -  int Depth = 1; -  while (Depth > 0 && !eof()) { -    // Parse the formal parameter list. -    if (FormatTok->is(OpenKind)) { -      ++Depth; -    } else if (FormatTok->is(CloseKind)) { -      --Depth; -    } -    nextToken(); -  } -} -  bool UnwrappedLineParser::tryToParseBracedList() {    if (FormatTok->BlockKind == BK_Unknown)      calculateBraceTypes(); @@ -1076,7 +1061,8 @@ bool UnwrappedLineParser::parseBracedList(bool ContinueOnSemicolons) {        if (FormatTok->is(Keywords.kw_function)) {          tryToParseJSFunction();          continue; -      } else if (FormatTok->is(TT_JsFatArrow)) { +      } +      if (FormatTok->is(TT_JsFatArrow)) {          nextToken();          // Fat arrows can be followed by simple expressions or by child blocks          // in curly braces. @@ -1780,15 +1766,12 @@ void UnwrappedLineParser::addUnwrappedLine() {      if (CurrentLines == &Lines)        printDebugInfo(*Line);    }); -  CurrentLines->push_back(*Line); +  CurrentLines->push_back(std::move(*Line));    Line->Tokens.clear();    if (CurrentLines == &Lines && !PreprocessorDirectives.empty()) { -    for (SmallVectorImpl<UnwrappedLine>::iterator -             I = PreprocessorDirectives.begin(), -             E = PreprocessorDirectives.end(); -         I != E; ++I) { -      CurrentLines->push_back(*I); -    } +    CurrentLines->append( +        std::make_move_iterator(PreprocessorDirectives.begin()), +        std::make_move_iterator(PreprocessorDirectives.end()));      PreprocessorDirectives.clear();    }  } diff --git a/lib/Format/UnwrappedLineParser.h b/lib/Format/UnwrappedLineParser.h index 6a6e56fea028..c2fa02957685 100644 --- a/lib/Format/UnwrappedLineParser.h +++ b/lib/Format/UnwrappedLineParser.h @@ -107,11 +107,6 @@ private:    bool tryToParseLambda();    bool tryToParseLambdaIntroducer();    void tryToParseJSFunction(); -  /// \brief Parses tokens until encountering the CloseKind token, but balances -  /// tokens when encountering more OpenKind tokens. Useful for e.g. parsing a -  /// curly brace delimited block that can contain nested blocks. -  /// The parser must be positioned on a token of OpenKind. -  void parseBalanced(tok::TokenKind OpenKind, tok::TokenKind CloseKind);    void addUnwrappedLine();    bool eof() const;    void nextToken(); diff --git a/lib/Format/WhitespaceManager.cpp b/lib/Format/WhitespaceManager.cpp index 4baaab1c9877..65395277f89a 100644 --- a/lib/Format/WhitespaceManager.cpp +++ b/lib/Format/WhitespaceManager.cpp @@ -402,7 +402,7 @@ void WhitespaceManager::appendNewlineText(std::string &Text, unsigned Newlines,      unsigned Offset =          std::min<int>(EscapedNewlineColumn - 1, PreviousEndOfTokenColumn);      for (unsigned i = 0; i < Newlines; ++i) { -      Text.append(std::string(EscapedNewlineColumn - Offset - 1, ' ')); +      Text.append(EscapedNewlineColumn - Offset - 1, ' ');        Text.append(UseCRLF ? "\\\r\n" : "\\\n");        Offset = 0;      } @@ -414,7 +414,7 @@ void WhitespaceManager::appendIndentText(std::string &Text,                                           unsigned WhitespaceStartColumn) {    switch (Style.UseTab) {    case FormatStyle::UT_Never: -    Text.append(std::string(Spaces, ' ')); +    Text.append(Spaces, ' ');      break;    case FormatStyle::UT_Always: {      unsigned FirstTabWidth = @@ -424,8 +424,8 @@ void WhitespaceManager::appendIndentText(std::string &Text,        Spaces -= FirstTabWidth;        Text.append("\t");      } -    Text.append(std::string(Spaces / Style.TabWidth, '\t')); -    Text.append(std::string(Spaces % Style.TabWidth, ' ')); +    Text.append(Spaces / Style.TabWidth, '\t'); +    Text.append(Spaces % Style.TabWidth, ' ');      break;    }    case FormatStyle::UT_ForIndentation: @@ -436,10 +436,10 @@ void WhitespaceManager::appendIndentText(std::string &Text,        if (Indentation > Spaces)          Indentation = Spaces;        unsigned Tabs = Indentation / Style.TabWidth; -      Text.append(std::string(Tabs, '\t')); +      Text.append(Tabs, '\t');        Spaces -= Tabs * Style.TabWidth;      } -    Text.append(std::string(Spaces, ' ')); +    Text.append(Spaces, ' ');      break;    }  } | 
