[clang] 5bf44aa - [clang-format][NFC] Refactor UnwrappedLineParser::parseBlock()
via cfe-commits
cfe-commits at lists.llvm.org
Thu May 26 13:56:56 PDT 2022
Author: owenca
Date: 2022-05-26T13:56:47-07:00
New Revision: 5bf44aa434ffe4d2e49806be20683e32135f4e16
URL: https://github.com/llvm/llvm-project/commit/5bf44aa434ffe4d2e49806be20683e32135f4e16
DIFF: https://github.com/llvm/llvm-project/commit/5bf44aa434ffe4d2e49806be20683e32135f4e16.diff
LOG: [clang-format][NFC] Refactor UnwrappedLineParser::parseBlock()
Differential Revision: https://reviews.llvm.org/D126358
Added:
Modified:
clang/lib/Format/UnwrappedLineParser.cpp
Removed:
################################################################################
diff --git a/clang/lib/Format/UnwrappedLineParser.cpp b/clang/lib/Format/UnwrappedLineParser.cpp
index fe57141407c0..9a5d85cead88 100644
--- a/clang/lib/Format/UnwrappedLineParser.cpp
+++ b/clang/lib/Format/UnwrappedLineParser.cpp
@@ -871,30 +871,33 @@ UnwrappedLineParser::IfStmtKind UnwrappedLineParser::parseBlock(
return IfKind;
}
- if (SimpleBlock && !KeepBraces) {
+ auto RemoveBraces = [=]() mutable {
+ if (KeepBraces || !SimpleBlock)
+ return false;
assert(Tok->isOneOf(TT_ControlStatementLBrace, TT_ElseLBrace));
assert(FormatTok->is(tok::r_brace));
+ const bool WrappedOpeningBrace = !Tok->Previous;
+ if (WrappedOpeningBrace && FollowedByComment)
+ return false;
const FormatToken *Previous = Tokens->getPreviousToken();
assert(Previous);
- if (Previous->isNot(tok::r_brace) || Previous->Optional) {
- assert(!CurrentLines->empty());
- const FormatToken *OpeningBrace = Tok;
- if (!Tok->Previous) { // Wrapped l_brace.
- if (FollowedByComment) {
- KeepBraces = true;
- } else {
- assert(Index > 0);
- --Index; // The line above the wrapped l_brace.
- OpeningBrace = nullptr;
- }
- }
- if (!KeepBraces && mightFitOnOneLine(CurrentLines->back()) &&
- (Tok->is(TT_ElseLBrace) ||
- mightFitOnOneLine((*CurrentLines)[Index], OpeningBrace))) {
- Tok->MatchingParen = FormatTok;
- FormatTok->MatchingParen = Tok;
- }
+ if (Previous->is(tok::r_brace) && !Previous->Optional)
+ return false;
+ assert(!CurrentLines->empty());
+ if (!mightFitOnOneLine(CurrentLines->back()))
+ return false;
+ if (Tok->is(TT_ElseLBrace))
+ return true;
+ if (WrappedOpeningBrace) {
+ assert(Index > 0);
+ --Index; // The line above the wrapped l_brace.
+ Tok = nullptr;
}
+ return mightFitOnOneLine((*CurrentLines)[Index], Tok);
+ };
+ if (RemoveBraces()) {
+ Tok->MatchingParen = FormatTok;
+ FormatTok->MatchingParen = Tok;
}
size_t PPEndHash = computePPHash();
More information about the cfe-commits
mailing list