diff options
-rw-r--r-- | include/clang/AST/DeclBase.h | 6 | ||||
-rw-r--r-- | lib/AST/DeclBase.cpp | 30 | ||||
-rw-r--r-- | lib/Sema/SemaDecl.cpp | 2 |
3 files changed, 21 insertions, 17 deletions
diff --git a/include/clang/AST/DeclBase.h b/include/clang/AST/DeclBase.h index 8d1ef8f06e..d39ad72bd7 100644 --- a/include/clang/AST/DeclBase.h +++ b/include/clang/AST/DeclBase.h @@ -363,7 +363,6 @@ public: const AttrVec &getAttrs() const; void swapAttrs(Decl *D); void dropAttrs(); - void dropWeakImportAttr(); void addAttr(Attr *A) { if (hasAttrs()) @@ -382,7 +381,10 @@ public: attr_iterator attr_end() const { return hasAttrs() ? getAttrs().end() : 0; } - + + template <typename T> + void dropAttr(); + template <typename T> specific_attr_iterator<T> specific_attr_begin() const { return specific_attr_iterator<T>(attr_begin()); diff --git a/lib/AST/DeclBase.cpp b/lib/AST/DeclBase.cpp index c183e61df8..69724a3d5e 100644 --- a/lib/AST/DeclBase.cpp +++ b/lib/AST/DeclBase.cpp @@ -520,20 +520,6 @@ void Decl::dropAttrs() { getASTContext().eraseDeclAttrs(this); } -void Decl::dropWeakImportAttr() { - if (!HasAttrs) return; - AttrVec &Attrs = getASTContext().getDeclAttrs(this); - for (llvm::SmallVectorImpl<Attr*>::iterator A = Attrs.begin(); - A != Attrs.end(); ++A) { - if (isa<WeakImportAttr>(*A)) { - Attrs.erase(A); - break; - } - } - if (Attrs.empty()) - HasAttrs = false; -} - const AttrVec &Decl::getAttrs() const { assert(HasAttrs && "No attrs to get!"); return getASTContext().getDeclAttrs(this); @@ -585,6 +571,22 @@ Decl *Decl::castFromDeclContext (const DeclContext *D) { } } +template <typename T> +void Decl::dropAttr() { + if (!HasAttrs) return; + AttrVec &Attrs = getASTContext().getDeclAttrs(this); + for (unsigned i = 0, e = Attrs.size(); i != e; ++i) { + if (isa<T>(Attrs[i])) { + Attrs.erase(Attrs.begin() + i); + --i, --e; + } + } + if (Attrs.empty()) + HasAttrs = false; +} +// Force instantiation for WeakImportAttr which gets used. +template void Decl::dropAttr<WeakImportAttr>(); + DeclContext *Decl::castToDeclContext(const Decl *D) { Decl::Kind DK = D->getKind(); switch(DK) { diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 487390bc29..4a000e9fc2 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -2046,7 +2046,7 @@ void Sema::MergeVarDecl(VarDecl *New, LookupResult &Previous) { Diag(New->getLocation(), diag::warn_weak_import) << New->getDeclName(); Diag(Old->getLocation(), diag::note_previous_definition); // Remove weak_import attribute on new declaration. - New->dropWeakImportAttr(); + New->dropAttr<WeakImportAttr>(); } // Merge the types. |