зеркало из https://github.com/microsoft/clang-1.git
Patch to diagnose a variety of misuse of property
attributes. Example would be, readonly, assign or assign, copy, etc. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@60620 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
5c37de7885
Коммит
567c8df364
|
@ -1229,12 +1229,22 @@ void Sema::CheckObjCPropertyAttributes(QualType PropertyTy,
|
||||||
unsigned &Attributes) {
|
unsigned &Attributes) {
|
||||||
// FIXME: Improve the reported location.
|
// FIXME: Improve the reported location.
|
||||||
|
|
||||||
// readonly and readwrite conflict.
|
// readonly and readwrite/assign/retain/copy conflict.
|
||||||
if ((Attributes & ObjCDeclSpec::DQ_PR_readonly) &&
|
if ((Attributes & ObjCDeclSpec::DQ_PR_readonly) &&
|
||||||
(Attributes & ObjCDeclSpec::DQ_PR_readwrite)) {
|
(Attributes & (ObjCDeclSpec::DQ_PR_readwrite |
|
||||||
|
ObjCDeclSpec::DQ_PR_assign |
|
||||||
|
ObjCDeclSpec::DQ_PR_copy |
|
||||||
|
ObjCDeclSpec::DQ_PR_retain))) {
|
||||||
|
const char * which = (Attributes & ObjCDeclSpec::DQ_PR_readwrite) ?
|
||||||
|
"readwrite" :
|
||||||
|
(Attributes & ObjCDeclSpec::DQ_PR_assign) ?
|
||||||
|
"assign" :
|
||||||
|
(Attributes & ObjCDeclSpec::DQ_PR_copy) ?
|
||||||
|
"copy" : "retain";
|
||||||
|
|
||||||
Diag(Loc, diag::err_objc_property_attr_mutually_exclusive)
|
Diag(Loc, diag::err_objc_property_attr_mutually_exclusive)
|
||||||
<< "readonly" << "readwrite";
|
<< "readonly" << which;
|
||||||
Attributes &= ~ObjCDeclSpec::DQ_PR_readonly;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for copy or retain on non-object types.
|
// Check for copy or retain on non-object types.
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
@property(retain) id Y;
|
@property(retain) id Y;
|
||||||
@property(assign) id Z;
|
@property(assign) id Z;
|
||||||
@property(assign) id K;
|
@property(assign) id K;
|
||||||
@property(assign, readonly) id N;
|
@property(readonly) id N;
|
||||||
@property(retain) id M;
|
@property(retain) id M;
|
||||||
@property(retain) id V;
|
@property(retain) id V;
|
||||||
@property(retain) id W;
|
@property(retain) id W;
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
B *iv1;
|
B *iv1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@property(assign,readonly) int p0;
|
@property(readonly) int p0;
|
||||||
@property(assign,nonatomic,readwrite) int p1;
|
@property(assign,nonatomic,readwrite) int p1;
|
||||||
@property(copy) id p2;
|
@property(copy) id p2;
|
||||||
@property(retain) id p3;
|
@property(retain) id p3;
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
id _object;
|
id _object;
|
||||||
id _object1;
|
id _object1;
|
||||||
}
|
}
|
||||||
@property(readonly, assign) id object;
|
@property(readonly) id object;
|
||||||
@property(readwrite, assign) id object1;
|
@property(readwrite, assign) id object1;
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
// RUN: clang -fsyntax-only -verify %s
|
||||||
|
|
||||||
|
@protocol P0
|
||||||
|
@property(readonly,assign) id X; // expected-error {{property attributes 'readonly' and 'assign' are mutually exclusive}}
|
||||||
|
@end
|
||||||
|
|
||||||
|
@protocol P1
|
||||||
|
@property(readonly,retain) id X; // expected-error {{property attributes 'readonly' and 'retain' are mutually exclusive}}
|
||||||
|
@end
|
||||||
|
|
||||||
|
@protocol P2
|
||||||
|
@property(readonly,copy) id X; // expected-error {{property attributes 'readonly' and 'copy' are mutually exclusive}}
|
||||||
|
@end
|
||||||
|
|
||||||
|
@protocol P3
|
||||||
|
@property(readonly,readwrite) id X; // expected-error {{property attributes 'readonly' and 'readwrite' are mutually exclusive}}
|
||||||
|
@end
|
||||||
|
|
||||||
|
@protocol P4
|
||||||
|
@property(assign,copy) id X; // expected-error {{property attributes 'assign' and 'copy' are mutually exclusive}}
|
||||||
|
@end
|
||||||
|
|
||||||
|
@protocol P5
|
||||||
|
@property(assign,retain) id X; // expected-error {{property attributes 'assign' and 'retain' are mutually exclusive}}
|
||||||
|
@end
|
||||||
|
|
||||||
|
@protocol P6
|
||||||
|
@property(copy,retain) id X; // expected-error {{property attributes 'copy' and 'retain' are mutually exclusive}}
|
||||||
|
@end
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,6 @@
|
||||||
@end
|
@end
|
||||||
|
|
||||||
@interface NOW : I
|
@interface NOW : I
|
||||||
@property (readonly, retain) id d1; // expected-warning {{attribute 'readonly' of property 'd1' restricts attribute 'readwrite' of property inherited from 'I'}} expected-warning {{property 'd1' 'copy' attribute does not match the property inherited from 'I'}}
|
@property (readonly) id d1; // expected-warning {{attribute 'readonly' of property 'd1' restricts attribute 'readwrite' of property inherited from 'I'}} expected-warning {{property 'd1' 'copy' attribute does not match the property inherited from 'I'}}
|
||||||
@property (readwrite, copy) I* d2; // expected-warning {{property type 'I *' does not match property type inherited from 'I'}}
|
@property (readwrite, copy) I* d2; // expected-warning {{property type 'I *' does not match property type inherited from 'I'}}
|
||||||
@end
|
@end
|
||||||
|
|
Загрузка…
Ссылка в новой задаче