Skip to content

Commit

Permalink
release/18.x: [clang-format] Fix a regression in annotating BK_Braced…
Browse files Browse the repository at this point in the history
…Init (llvm#87450)

Backport 7c9c38e
  • Loading branch information
owenca committed Apr 20, 2024
1 parent e6c3289 commit 497357a
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 7 deletions.
20 changes: 13 additions & 7 deletions clang/lib/Format/UnwrappedLineParser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -489,18 +489,23 @@ void UnwrappedLineParser::calculateBraceTypes(bool ExpectClassBody) {
};
SmallVector<StackEntry, 8> LBraceStack;
assert(Tok->is(tok::l_brace));

do {
// Get next non-comment, non-preprocessor token.
FormatToken *NextTok;
do {
NextTok = Tokens->getNextToken();
} while (NextTok->is(tok::comment));
while (NextTok->is(tok::hash) && !Line->InMacroBody) {
NextTok = Tokens->getNextToken();
do {
NextTok = Tokens->getNextToken();
} while (NextTok->is(tok::comment) ||
(NextTok->NewlinesBefore == 0 && NextTok->isNot(tok::eof)));

if (!Line->InMacroBody) {
// Skip PPDirective lines and comments.
while (NextTok->is(tok::hash)) {
do {
NextTok = Tokens->getNextToken();
} while (NextTok->NewlinesBefore == 0 && NextTok->isNot(tok::eof));

while (NextTok->is(tok::comment))
NextTok = Tokens->getNextToken();
}
}

switch (Tok->Tok.getKind()) {
Expand Down Expand Up @@ -631,6 +636,7 @@ void UnwrappedLineParser::calculateBraceTypes(bool ExpectClassBody) {
default:
break;
}

PrevTok = Tok;
Tok = NextTok;
} while (Tok->isNot(tok::eof) && !LBraceStack.empty());
Expand Down
12 changes: 12 additions & 0 deletions clang/unittests/Format/FormatTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -27019,6 +27019,18 @@ TEST_F(FormatTest, PPBranchesInBracedInit) {
"};");
}

TEST_F(FormatTest, PPDirectivesAndCommentsInBracedInit) {
verifyFormat("{\n"
" char *a[] = {\n"
" /* abc */ \"abc\",\n"
"#if FOO\n"
" /* xyz */ \"xyz\",\n"
"#endif\n"
" /* last */ \"last\"};\n"
"}",
getLLVMStyleWithColumns(30));
}

TEST_F(FormatTest, StreamOutputOperator) {
verifyFormat("std::cout << \"foo\" << \"bar\" << baz;");
verifyFormat("std::cout << \"foo\\n\"\n"
Expand Down
13 changes: 13 additions & 0 deletions clang/unittests/Format/TokenAnnotatorTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2609,6 +2609,19 @@ TEST_F(TokenAnnotatorTest, BraceKind) {
EXPECT_TOKEN(Tokens[13], tok::l_brace, TT_FunctionLBrace);
EXPECT_BRACE_KIND(Tokens[13], BK_Block);
EXPECT_BRACE_KIND(Tokens[14], BK_Block);

Tokens = annotate("{\n"
" char *a[] = {\n"
" /* abc */ \"abc\",\n"
"#if FOO\n"
" /* xyz */ \"xyz\",\n"
"#endif\n"
" /* last */ \"last\"};\n"
"}");
ASSERT_EQ(Tokens.size(), 25u) << Tokens;
EXPECT_BRACE_KIND(Tokens[0], BK_Block);
EXPECT_BRACE_KIND(Tokens[7], BK_BracedInit);
EXPECT_BRACE_KIND(Tokens[21], BK_BracedInit);
}

TEST_F(TokenAnnotatorTest, StreamOperator) {
Expand Down

0 comments on commit 497357a

Please sign in to comment.