diff options
author | Krasimir Georgiev <krasimir@google.com> | 2017-11-24 18:00:01 +0000 |
---|---|---|
committer | Krasimir Georgiev <krasimir@google.com> | 2017-11-24 18:00:01 +0000 |
commit | f09c42857f99bb38505a227a73fbc04c09d3e4f7 (patch) | |
tree | d71a51f1bdc2aa113a7fad58f3ea8fea27d33836 /clang/lib/Format | |
parent | ce2bd4dfd8d56512acd9f4c79f2894703e5977f1 (diff) | |
download | bcm5719-llvm-f09c42857f99bb38505a227a73fbc04c09d3e4f7.tar.gz bcm5719-llvm-f09c42857f99bb38505a227a73fbc04c09d3e4f7.zip |
[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
llvm-svn: 318960
Diffstat (limited to 'clang/lib/Format')
-rw-r--r-- | clang/lib/Format/UsingDeclarationsSorter.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/clang/lib/Format/UsingDeclarationsSorter.cpp b/clang/lib/Format/UsingDeclarationsSorter.cpp index 2c124ec78b1..ef0c7a7d5a4 100644 --- a/clang/lib/Format/UsingDeclarationsSorter.cpp +++ b/clang/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(); |