An API for manipulating Xcode project files.
Project* project = [[Project alloc] initWithFilePath:@"MyProject.xcodeproj"];
Group* group = [project groupWithPath:@"Main"];
ClassDefinition* classDefinition = [[ClassDefinition alloc] initWithName:@"MyNewClass"];
[classDefinition setHeader:@"<some-header-text>"];
[classDefinition setSource:@"<some-impl-text>"];
[group addClass:classDefinition];
[project save];
File* sourceFile = [project fileWithName:@"MyNewClass.m"];
Target* examples = [project targetWithName:@"Examples"];
[examples addMember:sourceFile];
[project save];
This time, we'll use a convenience method on xcode_Group to specify the targets at the same time:
XibDefinition* xibDefinition = [[XibDefinition alloc] initWithName:@"MyXibFile" content:@"<xibXml>"];
[group addXib:xibDefinition toTargets:[project targets]];
[project save];
FrameworkDefinition* frameworkDefinition =
[[FrameworkDefinition alloc] initWithFilePath:@"<framework path>" copyToDestination:NO];
[group addFramework:frameworkDefinition toTargets:[project targets]];
[project save];
Setting copyToDestination to YES, will cause the framework to be first copied to the group's directory within the project, and subsequently linked from there.
SourceFileDefinition* sourceFileDefinition = [[SourceFileDefinition alloc]
initWithName:@"MyImageFile.png" data:[NSData dataWithContentsOfFile:<your image file name>]
type:ImageResourcePNG];
[group addSourceFile:sourceFileDefinition];
[project save];
SourceFileDefinition* header = [[SourceFileDefinition alloc]
initWithName:@"SomeHeader.h" text:<your header text> type:SourceCodeHeader];
[group addSourceFile:header];
[project save];
Creates the reference in the project and writes the contents to disk. If a file already exists at the specified location, its contents will be updated.
[definition setFileOperationStyle:FileOperationStyleOverwrite];
Creates the reference in the project. If a file already exists at the specified location, the contents will not be updated.
[definition setFileOperationStyle:FileOperationStyleAcceptExisting];
Creates the reference in the project, but does not write to disk. The filesystem is expected to be updated through some other means.
[definition setFileOperationStyle:FileOperationStyleReferenceOnly];
You've just read them! The Source/Tests folder contains further usasge examples. A good starting point is to run the test target in Xcode. This will extract a test project to the /tmp directory, where you'll be able to see the outcome for yourself.
Open the project in XCode and choose Product/Build.
Includes Unit Tests, Integration Tests, Code Coverge and API reports installed to Xcode.
In addition to Xcode, requires the Appledoc and lcov packages. A nice way to install these is with MacPorts.
git clone https://github.com/tomaz/appledoc.git
sudo install-appledoc.sh
sudo port install lcov
NB: Xcode 4.3+ requires command-line tools to be installed separately.
ant
. . . are very welcome.
If you're using the API shoot me an email and tell me what you're doing with it.
- Xcode-editor has been tested on Xcode 4+. It should also work on earlier versions of Xcode. The AppCode IDE from JetBrains is not yet supported.
- Uses ARC and weak references so requires OSX 64 bit, and iOS 5. (Non ARC version coming soon.)
- expanz: A RAD framework that enables .NET developers in producing cross-platform and cloud apps.
- Less Painful: Automated functional testing for mobile applications.
- Level Helper: A RAD framework for developing 2D games on iOS & Android.
- Chris Ross of Hidden Memory (http://www.hiddenmemory.co.uk/)
- Paul Taykalo
- Vladislav Alekseev
Thanks!
Apache License, Version 2.0, January 2004, http://www.apache.org/licenses/
- © 2011 - 2012 expanz.com