Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to build an Objective-C static library?

I have some Objective-C classes, which I am currently using in both a Cocoa application (Mac OS X) and a Cocoa-Touch application (iOS). Currently, when I update those classes, I have to copy those updated .h and .m files to both projects. Not that big of deal, but I'm going to be using them in many more projects.

So, I want to build these classes into an Objective-C static library. And then link against that library in all other projects.

Is there a way to build a static library such that it works with both Cocoa and cocoa-touch applications?

I've tried just building a Cocoa static library with these classes, but I get various errors when I try to link against that library in my Cocoa application, and I'm sure that they are coming from the fact that I am not doing it right.

So, how do I build an Objective-C static library the right way? Do I have to build both a Cocoa-Touch and Cocoa static library? Or can I just do one? How is this done?

Are there any well-done tutorials on this subject?

I have searched the web and cannot seem to find a comprehensive tutorial on this subject, so I've posed the question here, in hopes that a great answer will be posted and this question can serve as a resource for me and for future questioners.

like image 651
Alex Avatar asked Jan 11 '11 05:01

Alex


People also ask

How do I create a static library in xcode?

Open Xcode , go to File->new->project, select iOS in the template selection window , choose “Cocoa Touch Static Library” and Press Next button. Give a name to the project and click Next button. This will create a project for you for creating a library.

How do I create an Objective-C project in Xcode?

To create a new Objective-C project select Create a New Xcode Project from the Welcome Screen. As an alternative you can select File > New > New Project… from the menu at the top of your screen. In the Mac OS X section left-hand pane select Application.


1 Answers

For XCode 5. These answers seem a bit out of date. You can see the main steps here http://www.raywenderlich.com/41377/creating-a-status-library-in-ios-tutorial . But Xcode 5 does a lot more work for you and now works nearly as you want it to.

1.Create new Static Library App in Xcode New Static Library in Xcode

2.You can delete any files it creates and add your own. Add your methods etc. Code Code Code

3.Little problem with Static Libraries, is that you can only build either for the device or run in the simulator. So we need to create a library that supports ARM and i386 Architectures, to do this we need to create a universal binary (so it will support simulator and on device builds).

Create a new target (File > New > Target). New Target

4.Select New Target then add a new build phase (Editor > Add Build Phase > Add Run Script Build Phase New Build Phase

5.Select the build phase and enter the script from this link into run script window. https://gist.github.com/sponno/7228256

Run Script Code

6.Now you need to build each architecture (simulator and iOS device)

6.2.Select our libary and then iOS Device, click build or run (Command + B)

6.3.Then for the Simulator (select the Library Icon very top left of Xcode and then the iOS Simulator) enter image description here

7.Now you want to build the BullsEye icon > iOS Device. This will be the aggregate target and will combine our two libraries into a new universal file.

8.Lets see if this all worked. Expanded the folder "Products" in the left tree, right click on the file ending with ".a" and "Show in Finder"

9.If this all works you should see the following files in finder. You will see the Library .a file and include files

10.The last step is easy, simply drag the "library.a file and the includes folder into your new Xcode project. enter image description here

enter image description here

In your new project, you wont have to do anything else, other than import the header files that want to use, but you do not have to change the linking flags, or header search paths. It will just work.

(any feedback appreciated) or please edit my post to improve clarity.

** BONUS POINTS *** Install VVDocumenter https://github.com/onevcat/VVDocumenter-Xcode and use this to document any header.h files that you will share with the library.

Now anyone that is using your library can opt+click to bring up context aware help for you classes.

Context Aware Help based on header file

like image 78
John Ballinger Avatar answered Oct 07 '22 02:10

John Ballinger