How should I respond to this warning?
warning: duplicate protocol definition of '...' is ignored
My protocol declaration is in its own .h file, and it is #import'ed in a few other files in my project.
Well, just in case, here's the entire header file with the protocol declaration:
#import <Foundation/Foundation.h>
@class Wrapper;
@protocol WrapperDelegate
@required
- (void)wrapper:(Wrapper *)wrapper didRetrieveData:(NSData *)data;
@optional
- (void)wrapperHasBadCredentials:(Wrapper *)wrapper;
- (void)wrapper:(Wrapper *)wrapper didCreateResourceAtURL:(NSString *)url;
- (void)wrapper:(Wrapper *)wrapper didFailWithError:(NSError *)error;
- (void)wrapper:(Wrapper *)wrapper didReceiveStatusCode:(int)statusCode;
@end
Thanks for any advice.
Check to make sure you don't have the header file added in your project twice, or two different files that both implement the protocol. This is what caused the warning to appear for me.
Yes I had the same problem. I was unable to find the duplicate header file in Xcode project. But when i went through the finder from the Xcode i found the 2 header file of the protocol in the project. Deleting one solved the problem. Thanks.
Just to supplement the existing answers here with the specific problem I encountered.
Basically, the compiler isn't lying. It is finding more than one definition of a class, protocol, enum, define, or whatever exists in the offending header files.
The fault could be a combination of your header files and the header search path.
At first, the issues seem puzzling as we know that the statement #import
will only import files that have not already been implemented. Therefore, unlike #include
, this problem shouldn't happen, right?
#import
does work. However, if your headers have been set up incorrectly then although it may encounter a file with the same name, e.g. MyLibrary.h
, if that file exists in two different places both of which are in the header search path then Xcode will perceive those as two different files.
In my case, I had a static library build phase which copied public headers.
The dependent products searched the folder above - defined in Build Settings as include/$(TARGET_NAME)
- and the source folder of my project.
That meant two different folders - both in the header search path - that contained the file MyLibrary.h
. Everything in that file would cause a duplicate or redefinition compiler warning or linker error.
TLDR: the same file may be in two different folders and both are in your header search path. Check your paths, and if you've incorporated a static library into the project or workspace, also check where the public headers are copied to as part of your investigation.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With