diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2009-02-18 17:52:36 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-02-18 17:52:36 +0000 |
commit | ba372b85524f712e5b97a176f6ce0197d365835d (patch) | |
tree | 9269ad70b414fe6efb71943109e5fb739b62ecc4 /lib/Sema/SemaDeclAttr.cpp | |
parent | 60800081361b0ffc114877b8abbc81cb57b4edf6 (diff) |
Cleanup objc's gc attributes code no longer needed.
This make warn-weak-field.m to fail (subject of
a followup patch).
attr-objc-gc.m no passes.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64925 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaDeclAttr.cpp')
-rw-r--r-- | lib/Sema/SemaDeclAttr.cpp | 33 |
1 files changed, 2 insertions, 31 deletions
diff --git a/lib/Sema/SemaDeclAttr.cpp b/lib/Sema/SemaDeclAttr.cpp index c4caec4d42..a385d97f68 100644 --- a/lib/Sema/SemaDeclAttr.cpp +++ b/lib/Sema/SemaDeclAttr.cpp @@ -568,35 +568,6 @@ static void HandleVisibilityAttr(Decl *d, const AttributeList &Attr, Sema &S) { d->addAttr(new VisibilityAttr(type)); } -static void HandleObjCGCAttr(Decl *D, const AttributeList &Attr, Sema &S) { - if (!Attr.getParameterName()) { - S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_not_string) - << "objc_gc" << 1; - return; - } - - if (Attr.getNumArgs() != 0) { - S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 1; - return; - } - - ObjCGCAttr::GCAttrTypes type; - if (Attr.getParameterName()->isStr("weak")) { - if (isa<FieldDecl>(D) && !isa<ObjCIvarDecl>(D)) - S.Diag(Attr.getLoc(), diag::warn_attribute_weak_on_field); - type = ObjCGCAttr::Weak; - } - else if (Attr.getParameterName()->isStr("strong")) - type = ObjCGCAttr::Strong; - else { - S.Diag(Attr.getLoc(), diag::warn_attribute_type_not_supported) - << "objc_gc" << Attr.getParameterName(); - return; - } - - D->addAttr(new ObjCGCAttr(type)); -} - static void HandleObjCExceptionAttr(Decl *D, const AttributeList &Attr, Sema &S) { if (Attr.getNumArgs() != 0) { @@ -1391,7 +1362,8 @@ static void ProcessDeclAttribute(Decl *D, const AttributeList &Attr, Sema &S) { switch (Attr.getKind()) { case AttributeList::AT_IBOutlet: HandleIBOutletAttr (D, Attr, S); break; case AttributeList::AT_address_space: - // Ignore this, this is a type attribute, handled by ProcessTypeAttributes. + case AttributeList::AT_objc_gc: + // Ignore these, these are type attributes, handled by ProcessTypeAttributes. break; case AttributeList::AT_alias: HandleAliasAttr (D, Attr, S); break; case AttributeList::AT_aligned: HandleAlignedAttr (D, Attr, S); break; @@ -1426,7 +1398,6 @@ static void ProcessDeclAttribute(Decl *D, const AttributeList &Attr, Sema &S) { case AttributeList::AT_transparent_union: HandleTransparentUnionAttr(D, Attr, S); break; - case AttributeList::AT_objc_gc: HandleObjCGCAttr (D, Attr, S); break; case AttributeList::AT_objc_exception: HandleObjCExceptionAttr(D, Attr, S); break; |