diff options
| author | Alex Lorenz <arphaman@gmail.com> | 2017-07-26 13:58:02 +0000 |
|---|---|---|
| committer | Alex Lorenz <arphaman@gmail.com> | 2017-07-26 13:58:02 +0000 |
| commit | 727c21e309d91331334d6059e4623509d75bba69 (patch) | |
| tree | 079e5eba1b720cbf0a064a9113a24f43d85def00 /clang/test/FixIt | |
| parent | 203c730719b3e89251adf68d444f9b14de6e70d8 (diff) | |
| download | bcm5719-llvm-727c21e309d91331334d6059e4623509d75bba69.tar.gz bcm5719-llvm-727c21e309d91331334d6059e4623509d75bba69.zip | |
unguarded availability: add a fixit for the "annotate '...'
with an availability attribute to silence" note
rdar://33539233
Differential Revision: https://reviews.llvm.org/D35726
llvm-svn: 309116
Diffstat (limited to 'clang/test/FixIt')
| -rw-r--r-- | clang/test/FixIt/fixit-availability.c | 8 | ||||
| -rw-r--r-- | clang/test/FixIt/fixit-availability.mm | 31 |
2 files changed, 39 insertions, 0 deletions
diff --git a/clang/test/FixIt/fixit-availability.c b/clang/test/FixIt/fixit-availability.c index 038dee08b13..4b3c8a43920 100644 --- a/clang/test/FixIt/fixit-availability.c +++ b/clang/test/FixIt/fixit-availability.c @@ -8,3 +8,11 @@ void use() { // CHECK: fix-it:{{.*}}:{[[@LINE-1]]:3-[[@LINE-1]]:3}:"if (__builtin_available(macOS 10.12, *)) {\n " // CHECK-NEXT: fix-it:{{.*}}:{[[@LINE-2]]:14-[[@LINE-2]]:14}:"\n } else {\n // Fallback on earlier versions\n }" } + +__attribute__((availability(macos, introduced=10.12))) +struct New { }; + +struct NoFixit { + struct New field; +}; +// CHECK-NOT: API_AVAILABLE diff --git a/clang/test/FixIt/fixit-availability.mm b/clang/test/FixIt/fixit-availability.mm index d044a73efdb..f6a18556944 100644 --- a/clang/test/FixIt/fixit-availability.mm +++ b/clang/test/FixIt/fixit-availability.mm @@ -109,3 +109,34 @@ void wrapDeclStmtUses() { anotherFunction(y); anotherFunction(x); } + +#define API_AVAILABLE(X) __attribute__((availability(macos, introduced=10.12))) // dummy macro + +API_AVAILABLE(macos(10.12)) +@interface NewClass +@end + +@interface OldButOfferFixit +@property(copy) NewClass *prop; +// CHECK: fix-it:{{.*}}:{[[@LINE-2]]:1-[[@LINE-2]]:1}:"API_AVAILABLE(macos(10.12))\n" + +- (NewClass *)fixitMe; +// CHECK: fix-it:{{.*}}:{[[@LINE-1]]:22-[[@LINE-1]]:22}:" API_AVAILABLE(macos(10.12))" +@end + +void oldButOfferFixitFn(NewClass *) { +// CHECK: fix-it:{{.*}}:{[[@LINE-1]]:1-[[@LINE-1]]:1}:"API_AVAILABLE(macos(10.12))\n" +} + +template<typename T> +struct OldButOfferFixitTag { +// CHECK: fix-it:{{.*}}:{[[@LINE-1]]:7-[[@LINE-1]]:7}:" API_AVAILABLE(macos(10.12))" + NewClass *x; +}; + +// Avoid a fixit for declarations that already have an attribute: +__attribute__((availability(macos, introduced=10.11))) +@interface WithoutFixit +@property(copy) NewClass *prop; +// CHECK-NOT: API_AVAILABLE +@end |

