forked from OSchip/llvm-project
Diagnose use of iboutletcollection on ivar/property
of non-object types. Radar 8308053. llvm-svn: 111296
This commit is contained in:
parent
8a05de4d29
commit
798f83239c
|
@ -828,6 +828,9 @@ def err_attribute_wrong_number_arguments : Error<
|
||||||
"attribute requires %0 argument(s)">;
|
"attribute requires %0 argument(s)">;
|
||||||
def err_iboutletcollection_type : Error<
|
def err_iboutletcollection_type : Error<
|
||||||
"invalid type %0 as argument of iboutletcollection attribue">;
|
"invalid type %0 as argument of iboutletcollection attribue">;
|
||||||
|
def err_iboutletcollection_object_type : Error<
|
||||||
|
"%select{ivar|property}1 with iboutletcollection attribue must "
|
||||||
|
"have object type (invalid %0)">;
|
||||||
def err_attribute_missing_parameter_name : Error<
|
def err_attribute_missing_parameter_name : Error<
|
||||||
"attribute requires unquoted parameter">;
|
"attribute requires unquoted parameter">;
|
||||||
def err_attribute_invalid_vector_type : Error<"invalid vector element type %0">;
|
def err_attribute_invalid_vector_type : Error<"invalid vector element type %0">;
|
||||||
|
|
|
@ -274,9 +274,23 @@ static void HandleIBOutletCollection(Decl *d, const AttributeList &Attr,
|
||||||
S.Diag(Attr.getLoc(), diag::err_attribute_iboutlet) << Attr.getName();
|
S.Diag(Attr.getLoc(), diag::err_attribute_iboutlet) << Attr.getName();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (const ValueDecl *VD = dyn_cast<ValueDecl>(d))
|
||||||
|
if (!VD->getType()->getAs<ObjCObjectPointerType>()) {
|
||||||
|
S.Diag(Attr.getLoc(), diag::err_iboutletcollection_object_type)
|
||||||
|
<< VD->getType() << 0;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (const ObjCPropertyDecl *PD = dyn_cast<ObjCPropertyDecl>(d))
|
||||||
|
if (!PD->getType()->getAs<ObjCObjectPointerType>()) {
|
||||||
|
S.Diag(Attr.getLoc(), diag::err_iboutletcollection_object_type)
|
||||||
|
<< PD->getType() << 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
IdentifierInfo *II = Attr.getParameterName();
|
IdentifierInfo *II = Attr.getParameterName();
|
||||||
if (!II)
|
if (!II)
|
||||||
II = &S.Context.Idents.get("id");
|
II = &S.Context.Idents.get("id");
|
||||||
|
|
||||||
Sema::TypeTy *TypeRep = S.getTypeName(*II, Attr.getLoc(),
|
Sema::TypeTy *TypeRep = S.getTypeName(*II, Attr.getLoc(),
|
||||||
S.getScopeForContext(d->getDeclContext()->getParent()));
|
S.getScopeForContext(d->getDeclContext()->getParent()));
|
||||||
if (!TypeRep) {
|
if (!TypeRep) {
|
||||||
|
|
|
@ -18,9 +18,12 @@ typedef void *PV;
|
||||||
@interface BAD {
|
@interface BAD {
|
||||||
__attribute__((iboutletcollection(I, 1))) id ivar1; // expected-error {{attribute requires 1 argument(s)}}
|
__attribute__((iboutletcollection(I, 1))) id ivar1; // expected-error {{attribute requires 1 argument(s)}}
|
||||||
__attribute__((iboutletcollection(B))) id ivar2; // expected-error {{invalid type 'B' as argument of iboutletcollection attribue}}
|
__attribute__((iboutletcollection(B))) id ivar2; // expected-error {{invalid type 'B' as argument of iboutletcollection attribue}}
|
||||||
__attribute__((iboutletcollection(PV))) id ivar3; // // expected-error {{invalid type 'PV' as argument of iboutletcollection attribue}}
|
__attribute__((iboutletcollection(PV))) id ivar3; // expected-error {{invalid type 'PV' as argument of iboutletcollection attribue}}
|
||||||
|
__attribute__((iboutletcollection(PV))) void *ivar4; // expected-error {{ivar with iboutletcollection attribue must have object type (invalid 'void *')}}
|
||||||
}
|
}
|
||||||
@property (nonatomic, retain) __attribute__((iboutletcollection(I,2,3))) id prop1; // expected-error {{attribute requires 1 argument(s)}}
|
@property (nonatomic, retain) __attribute__((iboutletcollection(I,2,3))) id prop1; // expected-error {{attribute requires 1 argument(s)}}
|
||||||
@property (nonatomic, retain) __attribute__((iboutletcollection(B))) id prop2; // expected-error {{invalid type 'B' as argument of iboutletcollection attribue}}
|
@property (nonatomic, retain) __attribute__((iboutletcollection(B))) id prop2; // expected-error {{invalid type 'B' as argument of iboutletcollection attribue}}
|
||||||
|
|
||||||
|
@property __attribute__((iboutletcollection(BAD))) int prop3; // expected-error {{property with iboutletcollection attribue must have object type (invalid 'int')}}
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue