forked from OSchip/llvm-project
Minor refactoring of sentinel warning on blocks. Add a test for this warning.
llvm-svn: 147641
This commit is contained in:
parent
1a0be3b1f2
commit
5c5e3b7e84
|
@ -1878,10 +1878,11 @@ static void handleSentinelAttr(Sema &S, Decl *D, const AttributeList &Attr) {
|
|||
S.Diag(Attr.getLoc(), diag::warn_attribute_sentinel_not_variadic) << 0;
|
||||
return;
|
||||
}
|
||||
} else if (isa<BlockDecl>(D)) {
|
||||
// Note! BlockDecl is typeless. Variadic diagnostics will be issued by the
|
||||
// caller.
|
||||
;
|
||||
} else if (BlockDecl *BD = dyn_cast<BlockDecl>(D)) {
|
||||
if (!BD->isVariadic()) {
|
||||
S.Diag(Attr.getLoc(), diag::warn_attribute_sentinel_not_variadic) << 1;
|
||||
return;
|
||||
}
|
||||
} else if (const VarDecl *V = dyn_cast<VarDecl>(D)) {
|
||||
QualType Ty = V->getType();
|
||||
if (Ty->isBlockPointerType() || Ty->isFunctionPointerType()) {
|
||||
|
|
|
@ -8806,12 +8806,6 @@ void Sema::ActOnBlockArguments(Declarator &ParamInfo, Scope *CurScope) {
|
|||
// Finally we can process decl attributes.
|
||||
ProcessDeclAttributes(CurScope, CurBlock->TheDecl, ParamInfo);
|
||||
|
||||
if (!isVariadic && CurBlock->TheDecl->getAttr<SentinelAttr>()) {
|
||||
Diag(ParamInfo.getAttributes()->getLoc(),
|
||||
diag::warn_attribute_sentinel_not_variadic) << 1;
|
||||
// FIXME: remove the attribute.
|
||||
}
|
||||
|
||||
// Put the parameter variables in scope. We can bail out immediately
|
||||
// if we don't have any.
|
||||
if (Params.empty())
|
||||
|
|
|
@ -3,7 +3,8 @@
|
|||
void (^e) (int arg, const char * format, ...) __attribute__ ((__sentinel__ (1,1)));
|
||||
|
||||
int main() {
|
||||
void (^bbad) (int arg, const char * format) __attribute__ ((__sentinel__)) ; // expected-warning {{sentinel' attribute only supported for variadic blocks}}
|
||||
void (^bbad) (int arg, const char * format) __attribute__ ((__sentinel__)) ; // expected-warning {{'sentinel' attribute only supported for variadic blocks}}
|
||||
bbad = ^void (int arg, const char * format) __attribute__ ((__sentinel__)) {} ; // expected-warning {{'sentinel' attribute only supported for variadic blocks}}
|
||||
void (^b) (int arg, const char * format, ...) __attribute__ ((__sentinel__)) = // expected-note {{block has been explicitly marked sentinel here}}
|
||||
^ __attribute__ ((__sentinel__)) (int arg, const char * format, ...) {};
|
||||
void (^z) (int arg, const char * format, ...) __attribute__ ((__sentinel__ (2))) = ^ __attribute__ ((__sentinel__ (2))) (int arg, const char * format, ...) {}; // expected-note {{block has been explicitly marked sentinel here}}
|
||||
|
|
Loading…
Reference in New Issue