const AttrVec &getAttrs() const;
void swapAttrs(Decl *D);
void dropAttrs();
- void dropWeakImportAttr();
void addAttr(Attr *A) {
if (hasAttrs())
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());
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);
}
}
+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) {
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.