2017-02-27 21:28:36 +08:00
|
|
|
//===- NamespaceEndCommentsFixerTest.cpp - Formatting unit tests ----------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "clang/Format/Format.h"
|
|
|
|
|
|
|
|
#include "clang/Frontend/TextDiagnosticPrinter.h"
|
|
|
|
#include "llvm/Support/Debug.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
#define DEBUG_TYPE "namespace-end-comments-fixer-test"
|
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace format {
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
class NamespaceEndCommentsFixerTest : public ::testing::Test {
|
|
|
|
protected:
|
|
|
|
std::string
|
|
|
|
fixNamespaceEndComments(llvm::StringRef Code,
|
2017-04-21 22:30:01 +08:00
|
|
|
const std::vector<tooling::Range> &Ranges,
|
2017-02-27 21:28:36 +08:00
|
|
|
const FormatStyle &Style = getLLVMStyle()) {
|
|
|
|
DEBUG(llvm::errs() << "---\n");
|
|
|
|
DEBUG(llvm::errs() << Code << "\n\n");
|
|
|
|
tooling::Replacements Replaces =
|
|
|
|
clang::format::fixNamespaceEndComments(Style, Code, Ranges, "<stdin>");
|
|
|
|
auto Result = applyAllReplacements(Code, Replaces);
|
|
|
|
EXPECT_TRUE(static_cast<bool>(Result));
|
|
|
|
DEBUG(llvm::errs() << "\n" << *Result << "\n\n");
|
|
|
|
return *Result;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string
|
|
|
|
fixNamespaceEndComments(llvm::StringRef Code,
|
|
|
|
const FormatStyle &Style = getLLVMStyle()) {
|
|
|
|
return fixNamespaceEndComments(
|
|
|
|
Code,
|
|
|
|
/*Ranges=*/{1, tooling::Range(0, Code.size())}, Style);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, AddsEndComment) {
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace\n",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}\n"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("inline namespace A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("inline namespace A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace ::A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace ::A",
|
|
|
|
fixNamespaceEndComments("namespace ::A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace ::A::B {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace ::A::B",
|
|
|
|
fixNamespaceEndComments("namespace ::A::B {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace /**/::/**/A/**/::/**/B/**/ {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace ::A::B",
|
|
|
|
fixNamespaceEndComments("namespace /**/::/**/A/**/::/**/B/**/ {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
"}\n"
|
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}\n"
|
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace B\n"
|
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}\n"
|
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int a;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int b;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace A\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
" int b;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int a;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace B",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int a;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int b;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
" int b;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int a;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int a1;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int a2;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
" int a2;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int a1;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int a1;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int a2;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
" int a2;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int a1;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int a;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int b;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace A\n"
|
|
|
|
"// comment about b\n"
|
|
|
|
"int b;",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int a;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int b;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}\n"
|
|
|
|
"// comment about b\n"
|
|
|
|
"int b;"));
|
|
|
|
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"namespace C {\n"
|
|
|
|
"namespace D {\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
"}\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace C\n"
|
|
|
|
"}// namespace B\n"
|
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"namespace C {\n"
|
|
|
|
"namespace D {\n"
|
|
|
|
"}\n"
|
|
|
|
"}\n"
|
|
|
|
"}\n"
|
|
|
|
"}"));
|
2017-03-07 22:07:43 +08:00
|
|
|
|
2017-06-14 20:29:47 +08:00
|
|
|
// Add comment for namespaces which will be 'compacted'
|
|
|
|
FormatStyle CompactNamespacesStyle = getLLVMStyle();
|
|
|
|
CompactNamespacesStyle.CompactNamespaces = true;
|
|
|
|
EXPECT_EQ("namespace out { namespace in {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}}// namespace out::in",
|
|
|
|
fixNamespaceEndComments("namespace out { namespace in {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}}",
|
|
|
|
CompactNamespacesStyle));
|
|
|
|
EXPECT_EQ("namespace out {\n"
|
|
|
|
"namespace in {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}\n"
|
|
|
|
"}// namespace out::in",
|
|
|
|
fixNamespaceEndComments("namespace out {\n"
|
|
|
|
"namespace in {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}\n"
|
|
|
|
"}",
|
|
|
|
CompactNamespacesStyle));
|
|
|
|
EXPECT_EQ("namespace out { namespace in {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"};}// namespace out::in",
|
|
|
|
fixNamespaceEndComments("namespace out { namespace in {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"};}",
|
|
|
|
CompactNamespacesStyle));
|
|
|
|
|
2017-03-07 22:07:43 +08:00
|
|
|
// Adds an end comment after a semicolon.
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};// namespace",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};// namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};// namespace A\n"
|
|
|
|
"// unrelated",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};\n"
|
|
|
|
"// unrelated"));
|
2017-02-27 21:28:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, AddsNewlineIfNeeded) {
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace A\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int k;",
|
2017-02-27 21:28:36 +08:00
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
|
|
|
"} int k;"));
|
2017-02-27 21:28:36 +08:00
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int k;",
|
2017-02-27 21:28:36 +08:00
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
|
|
|
"} int k;"));
|
2017-02-27 21:28:36 +08:00
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace A\n"
|
|
|
|
" namespace B {\n"
|
|
|
|
" int j;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int k;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}// namespace B",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int j;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"} namespace B {\n"
|
|
|
|
" int j;\n"
|
2017-03-02 17:54:44 +08:00
|
|
|
" int k;\n"
|
2017-02-27 21:28:36 +08:00
|
|
|
"}"));
|
2017-03-07 22:07:43 +08:00
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};// namespace\n"
|
|
|
|
"int k;",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};int k;"));
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};// namespace\n"
|
|
|
|
";",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"};;"));
|
2017-02-27 21:28:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, DoesNotAddEndCommentForShortNamespace) {
|
|
|
|
EXPECT_EQ("namespace {}", fixNamespaceEndComments("namespace {}"));
|
|
|
|
EXPECT_EQ("namespace A {}", fixNamespaceEndComments("namespace A {}"));
|
2017-03-02 17:54:44 +08:00
|
|
|
EXPECT_EQ("namespace A { a }",
|
|
|
|
fixNamespaceEndComments("namespace A { a }"));
|
2017-03-07 22:07:43 +08:00
|
|
|
EXPECT_EQ("namespace A { a };",
|
|
|
|
fixNamespaceEndComments("namespace A { a };"));
|
2017-02-27 21:28:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, DoesNotAddCommentAfterUnaffectedRBrace) {
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}",
|
|
|
|
// The range (16, 3) spans the 'int' above.
|
|
|
|
/*Ranges=*/{1, tooling::Range(16, 3)}));
|
2017-03-07 22:07:43 +08:00
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"};",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"};",
|
|
|
|
// The range (16, 3) spans the 'int' above.
|
|
|
|
/*Ranges=*/{1, tooling::Range(16, 3)}));
|
2017-02-27 21:28:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, DoesNotAddCommentAfterRBraceInPPDirective) {
|
|
|
|
EXPECT_EQ("#define SAD \\\n"
|
|
|
|
"namespace A { \\\n"
|
|
|
|
" int i; \\\n"
|
|
|
|
"}",
|
|
|
|
fixNamespaceEndComments("#define SAD \\\n"
|
|
|
|
"namespace A { \\\n"
|
|
|
|
" int i; \\\n"
|
|
|
|
"}"));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, KeepsValidEndComment) {
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // end anonymous namespace",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // end anonymous namespace"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} /* end of namespace A */",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} /* end of namespace A */"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A"));
|
|
|
|
EXPECT_EQ("namespace A::B {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // end namespace A::B",
|
|
|
|
fixNamespaceEndComments("namespace A::B {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // end namespace A::B"));
|
2017-03-07 22:07:43 +08:00
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}; // end namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}; // end namespace A"));
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}; /* unnamed namespace */",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}; /* unnamed namespace */"));
|
2017-02-27 21:28:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, UpdatesInvalidEndLineComment) {
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} //"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} //"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // banamespace A"));
|
2017-03-07 22:07:43 +08:00
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}; // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}; // banamespace A"));
|
2017-02-27 21:28:36 +08:00
|
|
|
// Updates invalid line comments even for short namespaces.
|
|
|
|
EXPECT_EQ("namespace A {} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {} // namespace"));
|
2017-03-07 22:07:43 +08:00
|
|
|
EXPECT_EQ("namespace A {}; // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {}; // namespace"));
|
2017-06-14 20:29:47 +08:00
|
|
|
|
|
|
|
// Update invalid comments for compacted namespaces.
|
|
|
|
FormatStyle CompactNamespacesStyle = getLLVMStyle();
|
|
|
|
CompactNamespacesStyle.CompactNamespaces = true;
|
|
|
|
EXPECT_EQ("namespace out { namespace in {\n"
|
|
|
|
"}} // namespace out::in",
|
|
|
|
fixNamespaceEndComments("namespace out { namespace in {\n"
|
|
|
|
"}} // namespace out",
|
|
|
|
CompactNamespacesStyle));
|
|
|
|
EXPECT_EQ("namespace out { namespace in {\n"
|
|
|
|
"}} // namespace out::in",
|
|
|
|
fixNamespaceEndComments("namespace out { namespace in {\n"
|
|
|
|
"}} // namespace in",
|
|
|
|
CompactNamespacesStyle));
|
|
|
|
EXPECT_EQ("namespace out { namespace in {\n"
|
|
|
|
"}\n"
|
|
|
|
"} // namespace out::in",
|
|
|
|
fixNamespaceEndComments("namespace out { namespace in {\n"
|
|
|
|
"}// banamespace in\n"
|
|
|
|
"} // namespace out",
|
|
|
|
CompactNamespacesStyle));
|
2017-02-27 21:28:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, UpdatesInvalidEndBlockComment) {
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} /* namespace A */"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} /* end namespace */"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} /**/"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} /* end unnamed namespace */"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} /* banamespace A */"));
|
2017-03-07 22:07:43 +08:00
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}; // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}; /* banamespace A */"));
|
2017-02-27 21:28:36 +08:00
|
|
|
EXPECT_EQ("namespace A {} // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {} /**/"));
|
2017-03-07 22:07:43 +08:00
|
|
|
EXPECT_EQ("namespace A {}; // namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {}; /**/"));
|
2017-02-27 21:28:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest,
|
|
|
|
DoesNotAddEndCommentForNamespacesControlledByMacros) {
|
|
|
|
EXPECT_EQ("#ifdef 1\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#elseif\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}\n"
|
|
|
|
"}\n",
|
|
|
|
fixNamespaceEndComments("#ifdef 1\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#elseif\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}\n"
|
|
|
|
"}\n"));
|
|
|
|
}
|
|
|
|
|
2017-07-28 15:56:14 +08:00
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, AddEndCommentForNamespacesAroundMacros) {
|
|
|
|
// Conditional blocks around are fine
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
"#if 1\n"
|
|
|
|
"int i;\n"
|
|
|
|
"#endif\n"
|
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
"#if 1\n"
|
|
|
|
"int i;\n"
|
|
|
|
"#endif\n"
|
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("#if 1\n"
|
|
|
|
"#endif\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("#if 1\n"
|
|
|
|
"#endif\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}// namespace A\n"
|
|
|
|
"#if 1\n"
|
|
|
|
"#endif",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}\n"
|
|
|
|
"#if 1\n"
|
|
|
|
"#endif"));
|
|
|
|
EXPECT_EQ("#if 1\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}// namespace A\n"
|
|
|
|
"#endif",
|
|
|
|
fixNamespaceEndComments("#if 1\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif"));
|
|
|
|
|
|
|
|
// Macro definition has no impact
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
"#define FOO\n"
|
|
|
|
"int i;\n"
|
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
"#define FOO\n"
|
|
|
|
"int i;\n"
|
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("#define FOO\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}// namespace A",
|
|
|
|
fixNamespaceEndComments("#define FOO\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}// namespace A\n"
|
|
|
|
"#define FOO\n",
|
|
|
|
fixNamespaceEndComments("namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}\n"
|
|
|
|
"#define FOO\n"));
|
|
|
|
|
|
|
|
// No replacement if open & close in different conditional blocks
|
|
|
|
EXPECT_EQ("#if 1\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"#if 1\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif",
|
|
|
|
fixNamespaceEndComments("#if 1\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"#if 1\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif"));
|
|
|
|
EXPECT_EQ("#ifdef A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"#ifdef B\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif",
|
|
|
|
fixNamespaceEndComments("#ifdef A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"#ifdef B\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif"));
|
|
|
|
|
|
|
|
// No replacement inside unreachable conditional block
|
|
|
|
EXPECT_EQ("#if 0\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif",
|
|
|
|
fixNamespaceEndComments("#if 0\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif"));
|
|
|
|
}
|
|
|
|
|
2017-02-27 21:28:36 +08:00
|
|
|
TEST_F(NamespaceEndCommentsFixerTest,
|
|
|
|
DoesNotAddEndCommentForNamespacesInMacroDeclarations) {
|
|
|
|
EXPECT_EQ("#ifdef 1\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#elseif\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}\n"
|
|
|
|
"}\n",
|
|
|
|
fixNamespaceEndComments("#ifdef 1\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#elseif\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
" int i;\n"
|
|
|
|
"}\n"
|
|
|
|
"}\n"));
|
2017-03-07 00:44:45 +08:00
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"}// namespace\n"
|
|
|
|
"#if A\n"
|
|
|
|
" int i;\n"
|
|
|
|
"#else\n"
|
|
|
|
" int j;\n"
|
|
|
|
"#endif",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
" int j;\n"
|
|
|
|
"}\n"
|
|
|
|
"#if A\n"
|
|
|
|
" int i;\n"
|
|
|
|
"#else\n"
|
|
|
|
" int j;\n"
|
|
|
|
"#endif"));
|
2017-03-07 01:29:25 +08:00
|
|
|
EXPECT_EQ("#if A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#else\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}",
|
|
|
|
fixNamespaceEndComments("#if A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#else\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"}"));
|
|
|
|
EXPECT_EQ("#if A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#else\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"} // namespace A",
|
|
|
|
fixNamespaceEndComments("#if A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#else\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"} // namespace A"));
|
|
|
|
EXPECT_EQ("#if A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#else\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"} // namespace B",
|
|
|
|
fixNamespaceEndComments("#if A\n"
|
|
|
|
"namespace A {\n"
|
|
|
|
"#else\n"
|
|
|
|
"namespace B {\n"
|
|
|
|
"#endif\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"} // namespace B"));
|
|
|
|
EXPECT_EQ("namespace A\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"#if A\n"
|
|
|
|
"}\n"
|
|
|
|
"#else\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif",
|
|
|
|
fixNamespaceEndComments("namespace A\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"#if A\n"
|
|
|
|
"}\n"
|
|
|
|
"#else\n"
|
|
|
|
"}\n"
|
|
|
|
"#endif"));
|
|
|
|
EXPECT_EQ("namespace A\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"#if A\n"
|
|
|
|
"} // namespace A\n"
|
|
|
|
"#else\n"
|
|
|
|
"} // namespace A\n"
|
|
|
|
"#endif",
|
|
|
|
fixNamespaceEndComments("namespace A\n"
|
|
|
|
"int i;\n"
|
|
|
|
"int j;\n"
|
|
|
|
"#if A\n"
|
|
|
|
"} // namespace A\n"
|
|
|
|
"#else\n"
|
|
|
|
"} // namespace A\n"
|
|
|
|
"#endif"));
|
2017-02-27 21:28:36 +08:00
|
|
|
}
|
2017-03-02 00:38:08 +08:00
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest,
|
|
|
|
DoesNotAddEndCommentForUnbalancedRBracesAfterNamespaceEnd) {
|
|
|
|
EXPECT_EQ("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace\n"
|
|
|
|
"}",
|
|
|
|
fixNamespaceEndComments("namespace {\n"
|
|
|
|
" int i;\n"
|
|
|
|
"} // namespace\n"
|
|
|
|
"}"));
|
|
|
|
}
|
2017-04-05 04:11:13 +08:00
|
|
|
|
|
|
|
TEST_F(NamespaceEndCommentsFixerTest, HandlesInlineAtEndOfLine_PR32438) {
|
|
|
|
EXPECT_EQ("template <int> struct a {};\n"
|
|
|
|
"struct a<bool{}> b() {\n"
|
|
|
|
"}\n"
|
|
|
|
"#define c inline\n"
|
|
|
|
"void d() {\n"
|
|
|
|
"}\n",
|
|
|
|
fixNamespaceEndComments("template <int> struct a {};\n"
|
|
|
|
"struct a<bool{}> b() {\n"
|
|
|
|
"}\n"
|
|
|
|
"#define c inline\n"
|
|
|
|
"void d() {\n"
|
|
|
|
"}\n"));
|
|
|
|
}
|
2017-02-27 21:28:36 +08:00
|
|
|
} // end namespace
|
|
|
|
} // end namespace format
|
|
|
|
} // end namespace clang
|