llvm-project/clang/test/SemaObjC/infer-availability-from-init.m
Erik Pilkington 4257857bf8 [Sema][ObjC] Infer availability of +new from availability of -init.
When defined in NSObject, +new will call -init. If -init has been marked
unavailable, diagnose uses of +new.

rdar://18335828

Differential revision: https://reviews.llvm.org/D51189

llvm-svn: 341874
2018-09-10 22:20:09 +00:00

59 lines
1.4 KiB
Objective-C

// RUN: %clang_cc1 -triple x86_64-apple-macosx-10.9 -Wunguarded-availability -fblocks -fsyntax-only -verify %s
__attribute__((objc_root_class))
@interface NSObject
+(instancetype)new;
-(instancetype)init;
@end
@interface MyObject : NSObject
-(instancetype)init __attribute__((unavailable)); // expected-note{{'init' has been explicitly marked unavailable here}}
@end
void usemyobject() {
[MyObject new]; // expected-error{{'new' is unavailable}}
}
@interface MyOtherObject : NSObject
+(instancetype)init __attribute__((unavailable));
+(instancetype)new;
@end
void usemyotherobject() {
[MyOtherObject new]; // no error; new is overrideen.
}
@interface NotGoodOverride : NSObject
+(instancetype)init __attribute__((unavailable));
-(instancetype)new;
+(instancetype)new: (int)x;
@end
void usenotgoodoverride() {
[NotGoodOverride new]; // no error
}
@interface NotNSObject
+(instancetype)new;
-(instancetype)init;
@end
@interface NotMyObject : NotNSObject
-(instancetype)init __attribute__((unavailable));
@end
void usenotmyobject() {
[NotMyObject new]; // no error; this isn't NSObject
}
@interface FromSelf : NSObject
-(instancetype)init __attribute__((unavailable)); // expected-note {{'init' has been explicitly marked unavailable here}}
+(FromSelf*)another_one;
@end
@implementation FromSelf
+(FromSelf*)another_one {
[self new]; // expected-error{{'new' is unavailable}}
}
@end