Fixed handling of comments before preprocessor directives.

Comments before preprocessor directives used to be stored with InPPDirective
flag set, which prevented correct comment splitting in this case. Fixed by
flushing comments before switching on InPPDirective. Added a new test and fixed
one of the existing tests.



git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@178261 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Alexander Kornienko 2013-03-28 18:40:55 +00:00
Родитель 03852c8717
Коммит 9fdc00a237
2 изменённых файлов: 10 добавлений и 2 удалений

Просмотреть файл

@ -822,6 +822,7 @@ void UnwrappedLineParser::readToken() {
while (!Line->InPPDirective && FormatTok.Tok.is(tok::hash) && while (!Line->InPPDirective && FormatTok.Tok.is(tok::hash) &&
((FormatTok.NewlinesBefore > 0 && FormatTok.HasUnescapedNewline) || ((FormatTok.NewlinesBefore > 0 && FormatTok.HasUnescapedNewline) ||
FormatTok.IsFirst)) { FormatTok.IsFirst)) {
flushComments(FormatTok.NewlinesBefore > 0);
// If there is an unfinished unwrapped line, we flush the preprocessor // If there is an unfinished unwrapped line, we flush the preprocessor
// directives only after that unwrapped line was finished later. // directives only after that unwrapped line was finished later.
bool SwitchToPreprocessorLines = bool SwitchToPreprocessorLines =

Просмотреть файл

@ -699,6 +699,13 @@ TEST_F(FormatTest, SplitsLongCxxComments) {
"//Don't add leading\n" "//Don't add leading\n"
"//whitespace", "//whitespace",
format("//Don't add leading whitespace", getLLVMStyleWithColumns(20))); format("//Don't add leading whitespace", getLLVMStyleWithColumns(20)));
EXPECT_EQ("// A comment before\n"
"// a macro\n"
"// definition\n"
"#define a b",
format("// A comment before a macro definition\n"
"#define a b",
getLLVMStyleWithColumns(20)));
} }
TEST_F(FormatTest, SplitsLongLinesInComments) { TEST_F(FormatTest, SplitsLongLinesInComments) {
@ -1203,13 +1210,13 @@ TEST_F(FormatTest, IndentsPPDirectiveInReducedSpace) {
} }
TEST_F(FormatTest, HandlePreprocessorDirectiveContext) { TEST_F(FormatTest, HandlePreprocessorDirectiveContext) {
EXPECT_EQ("// some comment\n" EXPECT_EQ("// somecomment\n"
"#include \"a.h\"\n" "#include \"a.h\"\n"
"#define A( \\\n" "#define A( \\\n"
" A, B)\n" " A, B)\n"
"#include \"b.h\"\n" "#include \"b.h\"\n"
"// somecomment\n", "// somecomment\n",
format(" // some comment\n" format(" // somecomment\n"
" #include \"a.h\"\n" " #include \"a.h\"\n"
"#define A(A,\\\n" "#define A(A,\\\n"
" B)\n" " B)\n"