diff options
author | Ted Kremenek <kremenek@apple.com> | 2013-02-09 07:13:16 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2013-02-09 07:13:16 +0000 |
commit | 7ee25676a50967e28baed5ec47adaaa9721899e9 (patch) | |
tree | 335edd843ae7ba3a065cf54faca16964993c5380 /clang | |
parent | 6c29cb3b7a233e7ddd5e48b348078eb2af91473a (diff) | |
download | bcm5719-llvm-7ee25676a50967e28baed5ec47adaaa9721899e9.tar.gz bcm5719-llvm-7ee25676a50967e28baed5ec47adaaa9721899e9.zip |
QoI: -Wreadonly-iboutlet-property should have the warning's location on the property.
There's no need to refer to the @implementation at all.
Fixes <rdar://problem/13186515>
llvm-svn: 174802
Diffstat (limited to 'clang')
-rw-r--r-- | clang/include/clang/Basic/DiagnosticSemaKinds.td | 4 | ||||
-rw-r--r-- | clang/lib/Sema/SemaObjCProperty.cpp | 4 | ||||
-rw-r--r-- | clang/test/SemaObjC/iboutlet.m | 14 |
3 files changed, 10 insertions, 12 deletions
diff --git a/clang/include/clang/Basic/DiagnosticSemaKinds.td b/clang/include/clang/Basic/DiagnosticSemaKinds.td index e190d7b5a62..615b598e77e 100644 --- a/clang/include/clang/Basic/DiagnosticSemaKinds.td +++ b/clang/include/clang/Basic/DiagnosticSemaKinds.td @@ -790,9 +790,9 @@ def warn_undeclared_selector : Warning< def warn_implicit_atomic_property : Warning< "property is assumed atomic by default">, InGroup<ImplicitAtomic>, DefaultIgnore; def note_auto_readonly_iboutlet_fixup_suggest : Note< - "readonly IBOutlet property should be changed to be readwrite">; + "property should be changed to be readwrite">; def warn_auto_readonly_iboutlet_property : Warning< - "readonly IBOutlet property when auto-synthesized may " + "readonly IBOutlet property '%0' when auto-synthesized may " "not work correctly with 'nib' loader">, InGroup<DiagGroup<"readonly-iboutlet-property">>; def warn_auto_implicit_atomic_property : Warning< diff --git a/clang/lib/Sema/SemaObjCProperty.cpp b/clang/lib/Sema/SemaObjCProperty.cpp index da7b4729b11..298bad8efbb 100644 --- a/clang/lib/Sema/SemaObjCProperty.cpp +++ b/clang/lib/Sema/SemaObjCProperty.cpp @@ -861,8 +861,8 @@ Decl *Sema::ActOnPropertyImplDecl(Scope *S, } if (!ReadWriteProperty) { - Diag(IC->getLocation(), diag::warn_auto_readonly_iboutlet_property); - Diag(property->getLocation(), diag::note_property_declare); + Diag(property->getLocation(), diag::warn_auto_readonly_iboutlet_property) + << property->getName(); SourceLocation readonlyLoc; if (LocPropertyAttribute(Context, "readonly", property->getLParenLoc(), readonlyLoc)) { diff --git a/clang/test/SemaObjC/iboutlet.m b/clang/test/SemaObjC/iboutlet.m index 93637497028..01e1bfc13be 100644 --- a/clang/test/SemaObjC/iboutlet.m +++ b/clang/test/SemaObjC/iboutlet.m @@ -9,17 +9,15 @@ #define IBOutlet __attribute__((iboutlet)) @interface I -@property (getter = MyGetter, readonly, assign) IBOutlet NSView *myView; // expected-note {{property declared here}} \ - // expected-note {{readonly IBOutlet property should be changed to be readwrite}} +@property (getter = MyGetter, readonly, assign) IBOutlet NSView *myView; // expected-warning {{readonly IBOutlet property 'myView' when auto-synthesized may not work correctly with 'nib' loader}} expected-note {{property should be changed to be readwrite}} -@property (readonly) IBOutlet NSView *myView1; // expected-note {{readonly IBOutlet property should be changed to be readwrite}} \ - // expected-note {{property declared here}} +@property (readonly) IBOutlet NSView *myView1; // expected-warning {{readonly IBOutlet property 'myView1' when auto-synthesized may not work correctly with 'nib' loader}} expected-note {{property should be changed to be readwrite}} -@property (getter = MyGetter, READONLY) IBOutlet NSView *myView2; // expected-note {{property declared here}} +@property (getter = MyGetter, READONLY) IBOutlet NSView *myView2; // expected-warning {{readonly IBOutlet property 'myView2' when auto-synthesized may not work correctly with 'nib' loader}} @end -@implementation I // expected-warning 3 {{readonly IBOutlet property when auto-synthesized may not work correctly with 'nib' loader}} +@implementation I @end @@ -29,7 +27,7 @@ @interface NSObject @end @interface RKTFHView : NSObject -@property( readonly ) __attribute__((iboutlet)) UILabel *autoReadOnlyReadOnly; // expected-note {{property declared here}} expected-note {{readonly IBOutlet property should be changed to be readwrite}} +@property( readonly ) __attribute__((iboutlet)) UILabel *autoReadOnlyReadOnly; // expected-warning {{readonly IBOutlet property 'autoReadOnlyReadOnly' when auto-synthesized may not work correctly with 'nib' loader}} expected-note {{property should be changed to be readwrite}} @property( readonly ) __attribute__((iboutlet)) UILabel *autoReadOnlyReadWrite; @property( readonly ) __attribute__((iboutlet)) UILabel *synthReadOnlyReadWrite; @end @@ -39,6 +37,6 @@ @property( readwrite ) __attribute__((iboutlet)) UILabel *synthReadOnlyReadWrite; @end -@implementation RKTFHView // expected-warning {{readonly IBOutlet property when auto-synthesized may not work correctly with 'nib' loader}} +@implementation RKTFHView @synthesize synthReadOnlyReadWrite=_synthReadOnlyReadWrite; @end |