forked from OSchip/llvm-project
[clang-format] calculate MaxInsertOffset in the original code correctly.
Reviewers: djasper Subscribers: klimek, cfe-commits Differential Revision: https://reviews.llvm.org/D27615 llvm-svn: 289203
This commit is contained in:
parent
6bd372bae7
commit
21d1032855
|
@ -1677,7 +1677,9 @@ fixCppIncludeInsertions(StringRef Code, const tooling::Replacements &Replaces,
|
||||||
unsigned MinInsertOffset =
|
unsigned MinInsertOffset =
|
||||||
getOffsetAfterHeaderGuardsAndComments(FileName, Code, Style);
|
getOffsetAfterHeaderGuardsAndComments(FileName, Code, Style);
|
||||||
StringRef TrimmedCode = Code.drop_front(MinInsertOffset);
|
StringRef TrimmedCode = Code.drop_front(MinInsertOffset);
|
||||||
|
// Max insertion offset in the original code.
|
||||||
unsigned MaxInsertOffset =
|
unsigned MaxInsertOffset =
|
||||||
|
MinInsertOffset +
|
||||||
getMaxHeaderInsertionOffset(FileName, TrimmedCode, Style);
|
getMaxHeaderInsertionOffset(FileName, TrimmedCode, Style);
|
||||||
SmallVector<StringRef, 32> Lines;
|
SmallVector<StringRef, 32> Lines;
|
||||||
TrimmedCode.split(Lines, '\n');
|
TrimmedCode.split(Lines, '\n');
|
||||||
|
|
|
@ -916,6 +916,30 @@ TEST_F(CleanUpReplacementsTest, CanInsertAfterComment) {
|
||||||
EXPECT_EQ(Expected, apply(Code, Replaces));
|
EXPECT_EQ(Expected, apply(Code, Replaces));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_F(CleanUpReplacementsTest, LongCommentsInTheBeginningOfFile) {
|
||||||
|
std::string Code = "// Loooooooooooooooooooooooooong comment\n"
|
||||||
|
"// Loooooooooooooooooooooooooong comment\n"
|
||||||
|
"// Loooooooooooooooooooooooooong comment\n"
|
||||||
|
"#include <string>\n"
|
||||||
|
"#include <vector>\n"
|
||||||
|
"\n"
|
||||||
|
"#include \"a.h\"\n"
|
||||||
|
"#include \"b.h\"\n";
|
||||||
|
std::string Expected = "// Loooooooooooooooooooooooooong comment\n"
|
||||||
|
"// Loooooooooooooooooooooooooong comment\n"
|
||||||
|
"// Loooooooooooooooooooooooooong comment\n"
|
||||||
|
"#include <string>\n"
|
||||||
|
"#include <vector>\n"
|
||||||
|
"\n"
|
||||||
|
"#include \"a.h\"\n"
|
||||||
|
"#include \"b.h\"\n"
|
||||||
|
"#include \"third.h\"\n";
|
||||||
|
tooling::Replacements Replaces =
|
||||||
|
toReplacements({createInsertion("#include \"third.h\"")});
|
||||||
|
Style = format::getGoogleStyle(format::FormatStyle::LanguageKind::LK_Cpp);
|
||||||
|
EXPECT_EQ(Expected, apply(Code, Replaces));
|
||||||
|
}
|
||||||
|
|
||||||
TEST_F(CleanUpReplacementsTest, CanDeleteAfterCode) {
|
TEST_F(CleanUpReplacementsTest, CanDeleteAfterCode) {
|
||||||
std::string Code = "#include \"a.h\"\n"
|
std::string Code = "#include \"a.h\"\n"
|
||||||
"void f() {}\n"
|
"void f() {}\n"
|
||||||
|
|
Loading…
Reference in New Issue