penagos updated this revision to Diff 338648. penagos added a comment. Update Format test
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D100778/new/ https://reviews.llvm.org/D100778 Files: clang/lib/Format/TokenAnnotator.cpp clang/unittests/Format/FormatTest.cpp Index: clang/unittests/Format/FormatTest.cpp =================================================================== --- clang/unittests/Format/FormatTest.cpp +++ clang/unittests/Format/FormatTest.cpp @@ -7649,6 +7649,8 @@ verifyFormat("a<int> = 1;", Style); verifyFormat("a<int> >>= 1;", Style); + verifyFormat("test < a | b >> c;"); + verifyFormat("test<test<a | b>> c;"); verifyFormat("test >> a >> b;"); verifyFormat("test << a >> b;"); Index: clang/lib/Format/TokenAnnotator.cpp =================================================================== --- clang/lib/Format/TokenAnnotator.cpp +++ clang/lib/Format/TokenAnnotator.cpp @@ -119,7 +119,10 @@ // a statement. if (CurrentToken->Next && CurrentToken->Next->is(tok::greater) && Left->ParentBracket != tok::less && - isKeywordWithCondition(*Line.First)) + (isKeywordWithCondition(*Line.First) || + CurrentToken->getStartOfNonWhitespace() == + CurrentToken->Next->getStartOfNonWhitespace().getLocWithOffset( + -1))) return false; Left->MatchingParen = CurrentToken; CurrentToken->MatchingParen = Left;
Index: clang/unittests/Format/FormatTest.cpp =================================================================== --- clang/unittests/Format/FormatTest.cpp +++ clang/unittests/Format/FormatTest.cpp @@ -7649,6 +7649,8 @@ verifyFormat("a<int> = 1;", Style); verifyFormat("a<int> >>= 1;", Style); + verifyFormat("test < a | b >> c;"); + verifyFormat("test<test<a | b>> c;"); verifyFormat("test >> a >> b;"); verifyFormat("test << a >> b;"); Index: clang/lib/Format/TokenAnnotator.cpp =================================================================== --- clang/lib/Format/TokenAnnotator.cpp +++ clang/lib/Format/TokenAnnotator.cpp @@ -119,7 +119,10 @@ // a statement. if (CurrentToken->Next && CurrentToken->Next->is(tok::greater) && Left->ParentBracket != tok::less && - isKeywordWithCondition(*Line.First)) + (isKeywordWithCondition(*Line.First) || + CurrentToken->getStartOfNonWhitespace() == + CurrentToken->Next->getStartOfNonWhitespace().getLocWithOffset( + -1))) return false; Left->MatchingParen = CurrentToken; CurrentToken->MatchingParen = Left;
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits