diff options
Diffstat (limited to 'clang/lib/Format/UnwrappedLineParser.cpp')
| -rw-r--r-- | clang/lib/Format/UnwrappedLineParser.cpp | 69 | 
1 files changed, 44 insertions, 25 deletions
| diff --git a/clang/lib/Format/UnwrappedLineParser.cpp b/clang/lib/Format/UnwrappedLineParser.cpp index 004c8364830..d63b38bcd1a 100644 --- a/clang/lib/Format/UnwrappedLineParser.cpp +++ b/clang/lib/Format/UnwrappedLineParser.cpp @@ -465,14 +465,14 @@ void UnwrappedLineParser::parsePPDirective() {    }  } -void UnwrappedLineParser::pushPPConditional() { -  if (!PPStack.empty() && PPStack.back() == PP_Unreachable) +void UnwrappedLineParser::conditionalCompilationCondition(bool Unreachable) { +  if (Unreachable || (!PPStack.empty() && PPStack.back() == PP_Unreachable))      PPStack.push_back(PP_Unreachable);    else      PPStack.push_back(PP_Conditional);  } -void UnwrappedLineParser::parsePPIf(bool IfDef) { +void UnwrappedLineParser::conditionalCompilationStart(bool Unreachable) {    ++PPBranchLevel;    assert(PPBranchLevel >= 0 && PPBranchLevel <= (int)PPLevelBranchIndex.size());    if (PPBranchLevel == (int)PPLevelBranchIndex.size()) { @@ -480,37 +480,22 @@ void UnwrappedLineParser::parsePPIf(bool IfDef) {      PPLevelBranchCount.push_back(0);    }    PPChainBranchIndex.push(0); -  nextToken(); -  bool IsLiteralFalse = (FormatTok->Tok.isLiteral() && -                         StringRef(FormatTok->Tok.getLiteralData(), -                                   FormatTok->Tok.getLength()) == "0") || -                        FormatTok->Tok.is(tok::kw_false); -  if ((!IfDef && IsLiteralFalse) || PPLevelBranchIndex[PPBranchLevel] > 0) { -    PPStack.push_back(PP_Unreachable); -  } else { -    pushPPConditional(); -  } -  parsePPUnknown(); +  bool Skip = PPLevelBranchIndex[PPBranchLevel] > 0; +  conditionalCompilationCondition(Unreachable || Skip);  } -void UnwrappedLineParser::parsePPElse() { +void UnwrappedLineParser::conditionalCompilationAlternative() {    if (!PPStack.empty())      PPStack.pop_back();    assert(PPBranchLevel < (int)PPLevelBranchIndex.size());    if (!PPChainBranchIndex.empty())      ++PPChainBranchIndex.top(); -  if (PPBranchLevel >= 0 && !PPChainBranchIndex.empty() && -      PPLevelBranchIndex[PPBranchLevel] != PPChainBranchIndex.top()) { -    PPStack.push_back(PP_Unreachable); -  } else { -    pushPPConditional(); -  } -  parsePPUnknown(); +  conditionalCompilationCondition( +      PPBranchLevel >= 0 && !PPChainBranchIndex.empty() && +      PPLevelBranchIndex[PPBranchLevel] != PPChainBranchIndex.top());  } -void UnwrappedLineParser::parsePPElIf() { parsePPElse(); } - -void UnwrappedLineParser::parsePPEndIf() { +void UnwrappedLineParser::conditionalCompilationEnd() {    assert(PPBranchLevel < (int)PPLevelBranchIndex.size());    if (PPBranchLevel >= 0 && !PPChainBranchIndex.empty()) {      if (PPChainBranchIndex.top() + 1 > PPLevelBranchCount[PPBranchLevel]) { @@ -524,6 +509,27 @@ void UnwrappedLineParser::parsePPEndIf() {      PPChainBranchIndex.pop();    if (!PPStack.empty())      PPStack.pop_back(); +} + +void UnwrappedLineParser::parsePPIf(bool IfDef) { +  nextToken(); +  bool IsLiteralFalse = (FormatTok->Tok.isLiteral() && +                         StringRef(FormatTok->Tok.getLiteralData(), +                                   FormatTok->Tok.getLength()) == "0") || +                        FormatTok->Tok.is(tok::kw_false); +  conditionalCompilationStart(!IfDef && IsLiteralFalse); +  parsePPUnknown(); +} + +void UnwrappedLineParser::parsePPElse() { +  conditionalCompilationAlternative(); +  parsePPUnknown(); +} + +void UnwrappedLineParser::parsePPElIf() { parsePPElse(); } + +void UnwrappedLineParser::parsePPEndIf() { +  conditionalCompilationEnd();    parsePPUnknown();  } @@ -1406,6 +1412,19 @@ void UnwrappedLineParser::readToken() {        flushComments(isOnNewLine(*FormatTok));        parsePPDirective();      } +    while (FormatTok->Type == TT_ConflictStart || +           FormatTok->Type == TT_ConflictEnd || +           FormatTok->Type == TT_ConflictAlternative) { +      if (FormatTok->Type == TT_ConflictStart) { +        conditionalCompilationStart(/*Unreachable=*/false); +      } else if (FormatTok->Type == TT_ConflictAlternative) { +        conditionalCompilationAlternative(); +      } else if(FormatTok->Type == TT_ConflictEnd) { +        conditionalCompilationEnd(); +      } +      FormatTok = Tokens->getNextToken(); +      FormatTok->MustBreakBefore = true; +    }      if (!PPStack.empty() && (PPStack.back() == PP_Unreachable) &&          !Line->InPPDirective) { | 

