Wednesday, May 8, 2013

Xcode Shared Code

Shared Code for iOS

We all have multiple iPhone, iPad (iOS) apps that we are creating. We all have a collection of classes, methods and categories that we have become accustom to having access to.
Seems like there are a million ways to "share" code between multiple projects.  After days of research, I believe I have found THE way to share code between your many projects.

What I want is to have multiple apps that are all individual applications in their own source control repository.  I also want to have one (or more) source control repository that contains code that ALL my projects can use.  I want to be able to easily edit (fix bugs, add enhancements) the shared code while in the middle of working on one of my apps.

Here is what I ended up with:
/Users/myname/dev/app1
/Users/myname/dev/app2
/Users/myname/dev/app3
/Users/myname/dev/sharedLib
/Users/myname/dev/sharedLib2

Each of the above folders is a separate GitHub repo. (Yea!)

STEP 1:  Create my first library of shared code

  1. Create "sharedLib" Xcode project (You can name it anything you like)
    1. File | New | Project...
    2. Select "Framework and Library" under iOS
    3. Select "Cocoa Touch Static Library"
    4. "Next"
    5. Product Name: "sharedLib"
    6. (everything else should be filled out, like Organization Name, Use ARC ...)
    7. "Next"
    8. Select your folder where all your projects and shared libraries will live (/Users/myname/dev in my case)
    9. "Create"
  2. Click the "Run" button to build the library (which is empty for now)
  3. The "Library" of shared code exists and is ready to use in your "apps"
  4. For testing purpose, add at least 1 class to the library and re-build it

STEP 2: Prepare your library for easy use by other apps

  1. We will be using the default .h file that was created with your library as the "public access" to all classes, methods and categories in your library.
  2. Open the .m file that was created with your library ("sharedLib.m") and comment out the simple content.  Do the same with the .h file.
  3. #import your classes in the .h file (#import "MyFunctions.h")

STEP 3: Add the library into an app

  1. Either use an existing app, or create a new app (in Xcode, duh)
  2. I'll assume the app is in a sibling folder to the shared library project
  3. Open a Finder window to the library project
    1. Right+Click on any file in your library project and select "Show in Finder..."
  4. Close the Xcode project for the shared library (You can only have a project open "once", and when it is shared with an app, the library will be open.)
  5. Add the "sharedLib.xcodeproj" to your app
    1. Have Xcode and Finder both on the screen at the same time
    2. Drag the sharedLib.xcodeproj file onto Xcode
    3. Drop it in the project window, at the bottom (You should see a cute little blue line at the bottom of your project list, probably below below a folder named "Products")
    4. (If you already have a sub-project added to your project, you can drop the xcodeproj file on the top-item -- the actual project, the one in blue)

STEP 4: Configure you app to use your library

  1. Note: We still have your app open in Xcode, and the library is shown in the project window
  2. Add the library as a "Build Dependency"
    1. Select the project (top item in the window)
    2. Make sure the "TARGETS" window has the app selected
    3. Select "Build Phases"
    4. Expand "Target Dependencies (0 items)"
    5. Click "+" (to add a new dependency)
    6. You will see a tree with about 5 items shown
    7. Select the one near the bottom called "sharedLib" (not the "tests" version) with the house icon
    8. Click "Add"
  3. Add the library as a "Library"
    1. Still in the same spot as you were ("Build Phases")
    2. Expand "Link Binary with Libraries (3 items)"
    3. Click "+" (to add a new library -- your new library)
    4. At the top of the dialog, you should see "libsharedlib.a" -- select it
    5. Click "Add" (Note: it may show in red)
  4. Add the library as "Searchable Headers"
    1. Still in the same spot as you were ("Build Phases")
    2. Switch to "Build Settings"
    3. Make sure you have "All" selected (not "Basic")
    4. Scroll way down to "Search Paths" (it is about in the middle)
    5. Find "Header Search Paths"
    6. Double-Click on the right-hand-side of "Header Search Paths" row
    7. Click "+" to add a new search path
    8. Type:  ../sharedLib/sharedLib   (This is the *relative* path to the library code folder)
    9. Note: if you use sub-folders in your library, change "non-recursive" to "recursive"
  5. Set linker options
    1. Still in the same spot as you were ("Build Settings")
    2. Scroll down to "Linking" (a couple above "Search Paths")
    3. Find "Other Linker Flags" (about the middle of this section)
    4. Double-Click on the right-hand-side of "Other Linker Flags" row
    5. Click "+" to add a new linker flag
    6. Type: -ObjC
    7. Note: This option will make categories in your library available in your app

STEP 5: Code up your app

  1. #import "sharedLib.h" in your .pch of your app
  2. Code your app, build, run, repeat
  3. If, and when, needed: code in the library, build app, run, repeat
  4. Live happy
  5. Build another app using the exact same library
  6. Make millions

NOTES:




No comments:

Post a Comment