[PATCH] D117759: [clang-format][NFC] Clean up tryMergeLessLess()
Owen Pan via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Jan 20 03:16:15 PST 2022
owenpan updated this revision to Diff 401579.
owenpan added a comment.
Further cleanup.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D117759/new/
https://reviews.llvm.org/D117759
Files:
clang/lib/Format/FormatTokenLexer.cpp
Index: clang/lib/Format/FormatTokenLexer.cpp
===================================================================
--- clang/lib/Format/FormatTokenLexer.cpp
+++ clang/lib/Format/FormatTokenLexer.cpp
@@ -430,19 +430,7 @@
return false;
auto First = Tokens.end() - 3;
- bool FourthTokenIsLess = false;
-
- if (Tokens.size() > 3) {
- auto Fourth = (Tokens.end() - 4)[0];
- FourthTokenIsLess = Fourth->is(tok::less);
-
- // Do not remove a whitespace between the two "<" e.g. "operator< <>".
- if (First[2]->is(tok::greater) && Fourth->is(tok::kw_operator))
- return false;
- }
-
- if (First[2]->is(tok::less) || First[1]->isNot(tok::less) ||
- First[0]->isNot(tok::less) || FourthTokenIsLess)
+ if (First[0]->isNot(tok::less) || First[1]->isNot(tok::less))
return false;
// Only merge if there currently is no whitespace between the two "<".
@@ -450,6 +438,15 @@
First[1]->WhitespaceRange.getEnd())
return false;
+ auto X = Tokens.size() > 3 ? First[-1] : nullptr;
+ auto Y = First[2];
+ if ((X && X->is(tok::less)) || Y->is(tok::less))
+ return false;
+
+ // Do not remove a whitespace between the two "<" e.g. "operator< <>".
+ if (X && X->is(tok::kw_operator) && Y->is(tok::greater))
+ return false;
+
First[0]->Tok.setKind(tok::lessless);
First[0]->TokenText = "<<";
First[0]->ColumnWidth += 1;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D117759.401579.patch
Type: text/x-patch
Size: 1374 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20220120/8d6d3b7a/attachment-0001.bin>
More information about the cfe-commits
mailing list