From: Krasimir Georgiev Date: Fri, 24 Nov 2017 18:00:01 +0000 (+0000) Subject: [clang-format] Deduplicate using declarations X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2aaf2c944d6c06d42df47ae4fa107a0bc8259fd7;p=clang [clang-format] Deduplicate using declarations Summary: This deduplicated equivalent using declarations within a block. Reviewers: bkramer Reviewed By: bkramer Subscribers: cfe-commits, klimek Differential Revision: https://reviews.llvm.org/D40435 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@318960 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Format/UsingDeclarationsSorter.cpp b/lib/Format/UsingDeclarationsSorter.cpp index 2c124ec78b..ef0c7a7d5a 100644 --- a/lib/Format/UsingDeclarationsSorter.cpp +++ b/lib/Format/UsingDeclarationsSorter.cpp @@ -130,7 +130,27 @@ void endUsingDeclarationBlock( UsingDeclarations->begin(), UsingDeclarations->end()); std::stable_sort(SortedUsingDeclarations.begin(), SortedUsingDeclarations.end()); + SortedUsingDeclarations.erase( + std::unique(SortedUsingDeclarations.begin(), + SortedUsingDeclarations.end(), + [](const UsingDeclaration &a, const UsingDeclaration &b) { + return a.Label == b.Label; + }), + SortedUsingDeclarations.end()); for (size_t I = 0, E = UsingDeclarations->size(); I < E; ++I) { + if (I >= SortedUsingDeclarations.size()) { + // This using declaration has been deduplicated, delete it. + auto Begin = + (*UsingDeclarations)[I].Line->First->WhitespaceRange.getBegin(); + auto End = (*UsingDeclarations)[I].Line->Last->Tok.getEndLoc(); + auto Range = CharSourceRange::getCharRange(Begin, End); + auto Err = Fixes->add(tooling::Replacement(SourceMgr, Range, "")); + if (Err) { + llvm::errs() << "Error while sorting using declarations: " + << llvm::toString(std::move(Err)) << "\n"; + } + continue; + } if ((*UsingDeclarations)[I].Line == SortedUsingDeclarations[I].Line) continue; auto Begin = (*UsingDeclarations)[I].Line->First->Tok.getLocation(); diff --git a/unittests/Format/UsingDeclarationsSorterTest.cpp b/unittests/Format/UsingDeclarationsSorterTest.cpp index 37427a51f8..c4d971367b 100644 --- a/unittests/Format/UsingDeclarationsSorterTest.cpp +++ b/unittests/Format/UsingDeclarationsSorterTest.cpp @@ -142,7 +142,6 @@ TEST_F(UsingDeclarationsSorterTest, UsingDeclarationOrder) { TEST_F(UsingDeclarationsSorterTest, SortsStably) { EXPECT_EQ("using a;\n" - "using a;\n" "using A;\n" "using a;\n" "using A;\n" @@ -151,11 +150,8 @@ TEST_F(UsingDeclarationsSorterTest, SortsStably) { "using a;\n" "using B;\n" "using b;\n" - "using b;\n" "using B;\n" "using b;\n" - "using b;\n" - "using b;\n" "using B;\n" "using b;", sortUsingDeclarations("using a;\n" @@ -355,6 +351,25 @@ TEST_F(UsingDeclarationsSorterTest, SortsUsingDeclarationsWithLeadingkComments) "/* comment */ using a;")); } +TEST_F(UsingDeclarationsSorterTest, DeduplicatesUsingDeclarations) { + EXPECT_EQ("using a;\n" + "using b;\n" + "using c;\n" + "\n" + "using a;\n" + "using e;", + sortUsingDeclarations("using c;\n" + "using a;\n" + "using b;\n" + "using a;\n" + "using b;\n" + "\n" + "using e;\n" + "using a;\n" + "using e;")); + +} + } // end namespace } // end namespace format } // end namespace clang