I'm building a Cocoa Touch Static Library. How should I decide whether to copy a header file as publ开发者_StackOverflow中文版ic, private, or project?
Public: The interface is finalized and meant to be used by your product’s clients. A public header is included in the product as readable source code without restriction.
Private: The interface isn’t intended for your clients or it’s in early stages of development. A private header is included in the product, but it’s marked “private”. Thus the symbols are visible to all clients, but clients should understand that they're not supposed to use them.
Project: The interface is for use only by implementation files in the current project. A project header is not included in the target, except in object code. The symbols are not visible to clients at all, only to you.
Source: Xcode Developer Library > Tools & Languages > IDEs > Project Editor Help > Setting the Visibility of a Header File
Randy's answer is good and gives you all the relevant background. I wanted to add some info to help you based on how you expect your library will be used.
PROJECT: If you are distributing your project, and expect users to include your project as a sub-project in their own, you should ensure your headers are marked as 'project'. Not doing so will lead to issues like this: Xcode 4 Archive Version Unspecified
Note that this applies to every sub-project...including sub-projects of sub-projects, recursively.
PUBLIC: If you expect users of your library to only link against your object (and NOT have your original project), make sure your headers are marked as 'public' (only for headers they'll need to refer to).
Objective-C Headers: Public, Private, Project
[Objective-C static library manual]
[Target Membership]
public - API which is exposed for consumer
private - API which is exposed for consumer but it is risky to use it
project - API is not visible for consumer. A kind of encapsulation on module level
File structure
ClassA.h - public
ClassB.h - project
ClassC.h - private
Headers folder is set by:
Public Headers Folder Path(PUBLIC_HEADERS_FOLDER_PATH)
//default value is
$(CONTENTS_FOLDER_PATH)/Headers
PrivateHeaders folder is set by:
Private Headers Folder Path(PRIVATE_HEADERS_FOLDER_PATH)
//default value is
$(CONTENTS_FOLDER_PATH)/PrivateHeaders
1.To expose Objective-C code for Objective-C or Swift consumers you should use .modulemap
and public headers
//Swift
import SomeModule
//Objective-C
@import SomeModule;
[.modulemap] -> only public headers or error
2.To expose Objective-C code for Objective-C consumer with non-module usage
//Objective-C
//umbrella
#import <ObjCFramework/ObjCFramework.h>
//specific руфвук
#import <ObjCFramework/ClassA.h>
//#import <ObjCFramework/ClassB.h> //error
#import <ObjCFramework/ClassC.h>
when you import a project header you get
Showing All Messages
'ObjCFramework/ClassB.h' file not found
精彩评论