PhoneGapLib is a static library that enables users to include PhoneGap in their iPhone application projects easily, and also create new PhoneGap based iPhone application projects through a Xcode project template.
Make sure you have installed the latest iPhone SDK. Download at http://developer.apple.com/iphone
- Launch "Terminal.app"
- Navigate to the folder where Makefile is (this folder)
- Type in "make" then press Enter
The installer should build "PhoneGapLibInstaller.pkg" into this folder, then:
- Quit Xcode
- Launch "PhoneGapLibInstaller.pkg" to install PhoneGapLib and the PhoneGap Xcode Template.
- Launch Xcode, then under the File menu, select "New Project...".
- Navigate to the "User Templates" section, select PhoneGap, then in the right pane, select "PhoneGap-based Application"
- Select the "Choose..." button, name your project and choose the location where you want the new project to be.
- Modify the contents of the "www" directory to add your HTML, CSS and Javascript.
- Launch "Terminal.app"
- Navigate to the folder where Makefile is (this folder)
- Type in "make uninstall" then press Enter
NOTE: It will ask you to confirm whether you want to delete the installed PhoneGapLib directory (just in case you made changes there). It will not ask for confirmation in deleting the installed Xcode template.
This installer will only install items under your home folder (signified by ~)
Items that will be installed:
- Xcode global var in ~/Library/Preferences/com.apple.Xcode.plist (which will be listed under Xcode Preferences -> Source Trees)
- PhoneGapLib Xcode static library project under ~/Documents/PhoneGapLib
- Xcode project template in ~/Library/Application Support/Developer/Shared/Xcode/Project Templates/PhoneGap
To uninstall:
- Remove the PHONEGAPLIB value in Xcode Preferences -> Source Trees
- Delete the ~/Documents/PhoneGapLib folder
- Delete the ~/Library/Application Support/Developer/Shared/Xcode/Project Templates/PhoneGap folder
There is a Xcode project that will test PhoneGapLib according to the mobile spec. There is some setup needed before the project can be run. You will also need git installed and in your path.
Set up the test project:
- Launch "Terminal.app"
- Type in "chmod 755 update_test.sh"
- Type in "./update_test.sh"
This will get the mobile-spec submodule and install it under the PhoneGapLibTests folder. You can then build and run the PhoneGapLibTest project to see the results.
You should run step (3) again before running any tests, to get the updated mobile-spec.
Q. PhoneGapLib.xcodeproj is red in my PhoneGap-based application and I get build errors?
A. The Xcode variable for PhoneGapLib is not set. Xcode must be closed when the installer is running. Either run the installer again, or add a PHONEGAPLIB variable in Xcode Preferences --> Source Trees, with the location of PhoneGapLib. The installer would have installed it in ~/Documents/PhoneGapLib.
Q. What is this warning I get when I am packaging the installer? "Warning: "Require Admin Authorization" is recommended but not enabled. Installation may fail."
A. You can safely ignore this warning, it will not affect installation. The installer only installs for the current user, thus it does not need Admin privileges.
Q. I get this "Invalid architecture" error. How do I fix it?
A. The Active SDK for the project is set to "Use Base SDK", change it to one of the iPhone targets in the drop-down. Unfortunately this is a user-specific project setting and cannot be set in the Xcode template.
Q. I get this "_kUTTypeImage" link error. How do I fix it?
A. This relates to framework added for the new UIImagePickerController delegate. Add "MobileCoreServices.framework" to your project. This only relates to pre-existing projects that have updated their PhoneGapLib. New projects should not see this error.
Q. I have Framework errors in red when creating a PhoneGap project in Xcode 3.2.3 for iOS 4.x? How do I fix it?
A. Change your Base SDK. Go to the Project Menu --> Edit Project Settings --> General Tab --> Base SDK for all Configurations. Change it to iOS Device 4.x
Q. I still have some "Invalid Architecture" errors. Yes, I've looked at the items above. How do I fix this?
A. The Base SDK for your project and PhoneGapLib must be exactly the same. Launch PhoneGapLib.xcodeproj (double-click on it in your project), and set its Base SDK to the same one in your project.
Q. I get a "no architectures to compile" error in PhoneGapLib when building for the Simulator in Xcode 4. Help?
A. This was working in Xcode 3, but not 4. Add the architecture "i386" to VALID_ARCHS in the PhoneGapLib project (do it for All Configurations). This has been fixed in the latest codebase as of Feb 6th 2011.
Q. I've tried almost everything and Xcode fails to compile PhoneGapDelegate.m in PhoneGapLib.
A. Check whether there is a space in the path to PhoneGapLib, particularly if there's a space in your home folder name. Unfortunately at this time you either have to change your home folder name (since PhoneGapLib is installed under it, in your Documents folder) or relocate PhoneGapLib to a location that has no space in the path (and make sure you update the PHONEGAPLIB Xcode variable in Xcode Preferences --> Source Trees). This has been fixed in the latest codebase as of Mar 7th 2011.
Q. I want to have a project-specific copy of PhoneGapLib for my project, not a global one. How do I do this?
A. In your project, there should be a PhoneGapBuildSettings.xcconfig file. Modify the PHONEGAPLIB variable in the file to point to your project specific PhoneGapLib folder. You can use relative paths, off $(PROJECT_DIR).
File them at http://phonegap.lighthouseapp.com