31

I'm writing an iPhone app against the Base 4.0 SDK, but I'm targeting OS 3.1.3 so OS 3 users can use the app.

I call:

[[UIApplication sharedApplication] setStatusBarHidden:YES animated:YES];

which is deprecated in iOS 4.0. I'm aware of this, and have measures in place to call the newer "withAnimation" version if we are running under iOS 4.0 or greater.

However, I'm getting a warning that I'm calling a deprecated SDK.

I'd like to disable this specific warning in this specific place. I want all other warnings (including the same deprecated warning in other locations)

Can this be accomplished in Xcode?

mokagio
  • 16,391
  • 3
  • 51
  • 58
David Coufal
  • 6,021
  • 5
  • 28
  • 30

4 Answers4

82

For CLANG, this works:

#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
  // Here I like to leave a comment to my future self to explain why I need this deprecated call
  NSString *myUDID = [[UIDevice currentDevice] uniqueIdentifier];
#pragma clang diagnostic pop

You can use it inside a method, which allows you to be very specific about the line that causes the warning you want to have ignored.

Guillaume
  • 21,685
  • 6
  • 63
  • 95
19

You might be able to use GCC pragmas. This should disable the deprecated warning for the enclosed function.

#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wdeprecated"
-(void)foo{
    // As Georg Fritzsche notes below, the pragmas only work outside of functions
    [[UIApplication sharedApplication] setStatusBarHidden:YES animated:YES];
}
#pragma GCC diagnostic pop

I don't know if this will work with Clang, but it should work with GCC.

Basically, it saves the state of the warnings/errors, disables the deprecated warning, compiles the function, then restores the state of the diagnostics.

paxswill
  • 1,200
  • 9
  • 13
8

You can use NSInvocation to get around the warnings independent of the compiler used:

UIApplication *app = [UIApplication sharedApplication];
SEL sel = @selector(setStatusBarHidden:animated:);
NSMethodSignature *sig = [app methodSignatureForSelector:sel];
NSInvocation *inv = [NSInvocation invocationWithMethodSignature:sig];
BOOL b = YES;
[inv setTarget:app];
[inv setSelector:sel];
[inv setArgument:&b atIndex:2];
[inv setArgument:&b atIndex:3];
[inv invoke];

Or in a less error-tolerant way:

UIApplication *app = [UIApplication sharedApplication];
SEL sel = @selector(setStatusBarHidden:animated:);
IMP imp = [app methodForSelector:sel];
imp(app, sel, YES, YES);
Georg Fritzsche
  • 97,545
  • 26
  • 194
  • 236
  • 1
    Could the `[NSMethodSignature signatureWithObjCTypes:"v@cc"]` be replaced with `[[UIApplication sharedApplication] methodSignatureForSelector:@selector(setStatusBarHidden)]` to make it easier to read? – paxswill Jun 29 '10 at 20:40
  • or `objc_msgSend(app, sel, YES, YES);` – user102008 Jun 04 '12 at 21:10
  • I have a similar reason as David Coufal to want to suppress specific warnings. I get the general idea of how I'd apply this solution to my problem but if it would be possible, could I ask if there are any special caveats I need to be aware of when using NSInvocation?I get the impression that this would be very easy to use in the wrong context by accident. – Leo Flaherty Nov 12 '15 at 15:10
  • you really shouldn't `NSInvocation` or any other runtime APIs for this. Use `[[UIApplication sharedApplication] performSelector:NSSelectorFromString(@"your_selector") withObject:arg1 withObject: arg2]` instead – lukas May 19 '17 at 12:01
4

you can perform it like this to overcome the warnings at once

#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
(void) methodUsingDeprecatedStuff { //use deprecated stuff }

or

Just paste this line before using your deprecated stuffs every time to avoid warnings

#pragma GCC diagnostic warning "-Wdeprecated-declarations"

this will remove the warnings.

Hope it will help you.

anish
  • 51
  • 2