Kin is a minimalistic tool to check whether your project.pbxproj file is correct.
Have you ever found yourself undoing a merge due to a broken Xcode build? Then Kin is your tool. It will parse your project configuration file and detect errors.
Kin is just a syntax checker built with ANTLR 4 with a very thin layer to be usable from command line. On the fly syntax checking integration for text editors and IDEs is a work in progress (see the "Text editor/IDE integration" section below).
Install Kin with your favorite python package manager.
Using pip
pip install kin
Using easy_install
easy_install kin
Once installed, use Kin from your Xcode project directory. Kin will automatically detect where your project configuration is located and check whether it is correct.
$> kin
CORRECT
If there is an error in your configuration file, Kin will return the offending line and a short description of the problem found.
$> kin
ERROR: line 400:3 mismatched input ')' expecting 'inputPaths'
Optionally, you can provide the location of your project.pbxproj to Kin:
$> kin myProject/myProject.xcodeproj/project.pbxproj
CORRECT
The following text editor and IDE integration packages are available:
Emacs
Feel free to add any useful feature to Kin, we will be glad to improve it with your help.
If you modify the grammar file (PBXProj.g4
), make sure you compile it using ANTLR. ANLTR version 4.6 can be installed with the following commands (the current version is 4.8 but is not compatible):
curl -O https://raw.githubusercontent.com/Homebrew/homebrew-core/92cd4dbae4ae77853e3693b4eb3c24d71855103f/Formula/antlr.rb
sed -i -e 's/EOS.undent/EOS/g' antlr.rb
brew install antlr.rb
After changes have been made to the PBXProj.g4
file it can be compiled with:
cd kin/grammar
bash /usr/local/Cellar/antlr/4.6/bin/antlr4 PBXProj.g4 -Dlanguage=Python2
The updated files can optionally be copied with this command for testing:
cp * path/to/site-packages/kin/grammar/
To run tests, first install the current version of kin by running pip install .
. Then you can execute ./tests/tester.py
to run all the scenarios we created.
Keep in mind that your PRs must be validated by Travis-CI.
Copyright 2016 Karumi
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.