diff options
| author | Ted Kremenek <kremenek@apple.com> | 2008-07-25 04:39:19 +0000 |
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2008-07-25 04:39:19 +0000 |
| commit | 39c59a88877d1e742a25d707cf373187bcf9a1af (patch) | |
| tree | f6de638f2ec2bb04b9fec2e01ac5d937f6bc3100 | |
| parent | 7334350d31fb31fccbf969a52a06a4f7cec55191 (diff) | |
| download | bcm5719-llvm-39c59a88877d1e742a25d707cf373187bcf9a1af.tar.gz bcm5719-llvm-39c59a88877d1e742a25d707cf373187bcf9a1af.zip | |
Implemented Sema support for attribute "unused".
llvm-svn: 54008
| -rw-r--r-- | clang/include/clang/AST/Attr.h | 27 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaDeclAttr.cpp | 20 |
2 files changed, 38 insertions, 9 deletions
diff --git a/clang/include/clang/AST/Attr.h b/clang/include/clang/AST/Attr.h index dd6f28f85e6..0ae0acb878d 100644 --- a/clang/include/clang/AST/Attr.h +++ b/clang/include/clang/AST/Attr.h @@ -27,22 +27,22 @@ public: enum Kind { Alias, Aligned, - Packed, Annotate, - NonNull, - NoReturn, Deprecated, - Weak, DLLImport, DLLExport, - NoThrow, + FastCall, Format, - Visibility, - FastCall, + IBOutletKind, // Clang-specific. Use "Kind" suffix to not conflict with + NonNull, + NoReturn, + NoThrow, + Packed, StdCall, TransparentUnion, - IBOutletKind // Clang-specific. Use "Kind" suffix to not conflict with - // the IBOutlet macro. + Unused, + Visibility, + Weak }; private: @@ -157,6 +157,15 @@ public: static bool classof(const DeprecatedAttr *A) { return true; } }; +class UnusedAttr : public Attr { +public: + UnusedAttr() : Attr(Unused) {} + + // Implement isa/cast/dyncast/etc. + static bool classof(const Attr *A) { return A->getKind() == Unused; } + static bool classof(const UnusedAttr *A) { return true; } +}; + class WeakAttr : public Attr { public: WeakAttr() : Attr(Weak) {} diff --git a/clang/lib/Sema/SemaDeclAttr.cpp b/clang/lib/Sema/SemaDeclAttr.cpp index 04e3f0557b7..9a38f6cf351 100644 --- a/clang/lib/Sema/SemaDeclAttr.cpp +++ b/clang/lib/Sema/SemaDeclAttr.cpp @@ -339,6 +339,25 @@ static void HandleNoReturnAttr(Decl *d, const AttributeList &Attr, Sema &S) { d->addAttr(new NoReturnAttr()); } +static void HandleUnusedAttr(Decl *d, const AttributeList &Attr, Sema &S) { + // check the attribute arguments. + if (Attr.getNumArgs() != 0) { + S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments, + std::string("0")); + return; + } + + VarDecl *VD = dyn_cast<VarDecl>(d); + + if (!VD) { + S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type, + "unused", "variable"); + return; + } + + d->addAttr(new UnusedAttr()); +} + static void HandleDeprecatedAttr(Decl *d, const AttributeList &Attr, Sema &S) { // check the attribute arguments. if (Attr.getNumArgs() != 0) { @@ -826,6 +845,7 @@ static void ProcessDeclAttribute(Decl *D, const AttributeList &Attr, Sema &S) { case AttributeList::AT_format: HandleFormatAttr (D, Attr, S); break; case AttributeList::AT_IBOutlet: HandleIBOutletAttr (D, Attr, S); break; case AttributeList::AT_nonnull: HandleNonNullAttr (D, Attr, S); break; + case AttributeList::AT_unused: HandleUnusedAttr (D, Attr, S); break; case AttributeList::AT_transparent_union: HandleTransparentUnionAttr(D, Attr, S); break; |

