diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2010-06-18 23:14:53 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2010-06-18 23:14:53 +0000 |
| commit | 0bf5ee74c473a394e0a484ad8b979f0972c75345 (patch) | |
| tree | dd7be138657f4406bd4bf5a7046692baf51e7136 /clang/lib/Sema/SemaDeclAttr.cpp | |
| parent | 2bfad417a17b2a60e22925e3d6e1f2e418926857 (diff) | |
| download | bcm5719-llvm-0bf5ee74c473a394e0a484ad8b979f0972c75345.tar.gz bcm5719-llvm-0bf5ee74c473a394e0a484ad8b979f0972c75345.zip | |
More Sema Check and a test case for init_priority attr.
(radar 8076356).
llvm-svn: 106350
Diffstat (limited to 'clang/lib/Sema/SemaDeclAttr.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaDeclAttr.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaDeclAttr.cpp b/clang/lib/Sema/SemaDeclAttr.cpp index b54bc1ed9f5..c5eb048577a 100644 --- a/clang/lib/Sema/SemaDeclAttr.cpp +++ b/clang/lib/Sema/SemaDeclAttr.cpp @@ -1189,12 +1189,27 @@ static void HandleInitPriorityAttr(Decl *d, const AttributeList &Attr, return; } + if (!isa<VarDecl>(d) || S.getCurFunctionOrMethodDecl()) { + S.Diag(Attr.getLoc(), diag::err_init_priority_object_attr); + Attr.setInvalid(); + return; + } + QualType T = dyn_cast<VarDecl>(d)->getType(); + if (S.Context.getAsArrayType(T)) + T = S.Context.getBaseElementType(T); + if (!T->getAs<RecordType>()) { + S.Diag(Attr.getLoc(), diag::err_init_priority_object_attr); + Attr.setInvalid(); + return; + } + if (Attr.getNumArgs() != 1) { S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 1; Attr.setInvalid(); return; } Expr *priorityExpr = static_cast<Expr *>(Attr.getArg(0)); + llvm::APSInt priority(32); if (priorityExpr->isTypeDependent() || priorityExpr->isValueDependent() || !priorityExpr->isIntegerConstantExpr(priority, S.Context)) { |

