forked from OSchip/llvm-project
Assortment of property attributes declared in continuation
class must match those of same property declared in its primary class. (Fixes radar 7352425) llvm-svn: 85843
This commit is contained in:
parent
31e1d43729
commit
a386d9533b
|
@ -1900,9 +1900,16 @@ Sema::DeclPtrTy Sema::ActOnProperty(Scope *S, SourceLocation AtLoc,
|
|||
// with continuation class's readwrite property attribute!
|
||||
unsigned PIkind = PIDecl->getPropertyAttributes();
|
||||
if (isReadWrite && (PIkind & ObjCPropertyDecl::OBJC_PR_readonly)) {
|
||||
if ((Attributes & ObjCPropertyDecl::OBJC_PR_nonatomic) !=
|
||||
(PIkind & ObjCPropertyDecl::OBJC_PR_nonatomic))
|
||||
unsigned assignRetainCopyNonatomic =
|
||||
(ObjCPropertyDecl::OBJC_PR_assign |
|
||||
ObjCPropertyDecl::OBJC_PR_retain |
|
||||
ObjCPropertyDecl::OBJC_PR_copy |
|
||||
ObjCPropertyDecl::OBJC_PR_nonatomic);
|
||||
if ((Attributes & assignRetainCopyNonatomic) !=
|
||||
(PIkind & assignRetainCopyNonatomic)) {
|
||||
Diag(AtLoc, diag::warn_property_attr_mismatch);
|
||||
Diag(PIDecl->getLocation(), diag::note_property_declare);
|
||||
}
|
||||
PIDecl->makeitReadWriteAttribute();
|
||||
if (Attributes & ObjCDeclSpec::DQ_PR_retain)
|
||||
PIDecl->setPropertyAttributes(ObjCPropertyDecl::OBJC_PR_retain);
|
||||
|
|
|
@ -5,12 +5,12 @@
|
|||
id _object;
|
||||
id _object1;
|
||||
}
|
||||
@property(readonly) id object;
|
||||
@property(readonly) id object; // expected-note {{property declared here}}
|
||||
@property(readwrite, assign) id object1; // expected-note {{property declared here}}
|
||||
@end
|
||||
|
||||
@interface ReadOnly ()
|
||||
@property(readwrite, copy) id object;
|
||||
@property(readwrite, copy) id object; // expected-warning {{property attribute in continuation class does not match the primary class}}
|
||||
@property(readonly) id object1; // expected-error {{property declaration in continuation class of 'ReadOnly' is to change a 'readonly' property to 'readwrite'}}
|
||||
@end
|
||||
|
||||
|
|
Loading…
Reference in New Issue