forked from OSchip/llvm-project
Stronger respect the input codes line breaks wrt. comments.
clang-format should not change whether or not there is a line break before a line comment as this strongly influences the percieved binding. User input: void f(int a, // b is awesome int b); void g(int a, // a is awesome int b); Before: void f(int a, // b is awesome int b); void g(int a, // a is awesome int b); After: <unchanged from input> llvm-svn: 172361
This commit is contained in:
parent
bb13a3c457
commit
942ee72aff
|
@ -901,9 +901,12 @@ public:
|
|||
if (Current.FormatTok.MustBreakBefore) {
|
||||
Current.MustBreakBefore = true;
|
||||
} else {
|
||||
if (Current.Type == TT_CtorInitializerColon || Current.Parent->Type ==
|
||||
TT_LineComment || (Current.is(tok::string_literal) &&
|
||||
Current.Parent->is(tok::string_literal))) {
|
||||
if (Current.Type == TT_LineComment) {
|
||||
Current.MustBreakBefore = Current.FormatTok.NewlinesBefore > 0;
|
||||
} else if (Current.Type == TT_CtorInitializerColon ||
|
||||
Current.Parent->Type == TT_LineComment ||
|
||||
(Current.is(tok::string_literal) &&
|
||||
Current.Parent->is(tok::string_literal))) {
|
||||
Current.MustBreakBefore = true;
|
||||
} else {
|
||||
Current.MustBreakBefore = false;
|
||||
|
@ -1219,7 +1222,10 @@ private:
|
|||
return false;
|
||||
|
||||
if (Right.is(tok::comment))
|
||||
return !Right.Children.empty();
|
||||
// We rely on MustBreakBefore being set correctly here as we should not
|
||||
// change the "binding" behavior of a comment.
|
||||
return false;
|
||||
|
||||
if (Right.is(tok::r_paren) || Right.is(tok::l_brace) ||
|
||||
Right.is(tok::greater))
|
||||
return false;
|
||||
|
|
|
@ -285,6 +285,14 @@ TEST_F(FormatTest, UnderstandsSingleLineComments) {
|
|||
verifyFormat("void f() {\n"
|
||||
" // Doesn't do anything\n"
|
||||
"}");
|
||||
verifyFormat("void f(int i, // some comment (probably for i)\n"
|
||||
" int j, // some comment (probably for j)\n"
|
||||
" int k); // some comment (probably for k)");
|
||||
verifyFormat("void f(int i,\n"
|
||||
" // some comment (probably for j)\n"
|
||||
" int j,\n"
|
||||
" // some comment (probably for k)\n"
|
||||
" int k);");
|
||||
|
||||
verifyFormat("int i // This is a fancy variable\n"
|
||||
" = 5;");
|
||||
|
|
Loading…
Reference in New Issue