I just tried to create a new phonegap 3.0 project... Note: I\'m new to phonegap. Anyways, I see the project folder contains:
.cordova
A lot of this stuff is old and doesn't really apply to the latest version of Apache Cordova. I'm using Apache Cordova 5.1.1 and this .gitignore allows me to still customize with custom icons etc while blocking all the stuff we don't need to version for both Android and IOS. Yes .gradle is used so don't remove it!
www/
.gradle/
build/
.tmp/
.temp/
coverage/
*.log
node_modules/
bower_components/
So I just figured this out through trial and error. The platforms
directory can be omitted if you are using phonegap local or remote build, as it is generated on the fly. All of the other folders, including the hidden folder .cordova
are required.
Expanding on @Jake Moshenko answer:
I like the idea of omitting the platforms
directory. In fact, I am am able to exclude both the plugins
and platforms
directories. A good starting point for the .gitignore
:
platforms/
plugins/
The problem with this is that clean copy of the repo must be initialized before you can actually work with it. It may make sense to create an init script such as:
#!/bin/bash
textReset=$(tput sgr0)
textGreen=$(tput setaf 2)
message_info () {
echo "${textGreen}[my-app]${textReset} $1"
}
message_info "Creating necessary directories..."
mkdir plugins
mkdir platforms
message_info "Adding platforms..."
# If using cordova, change to: cordova platform add android
phonegap build android
phonegap build ios
message_info "Adding plugins..."
# If using cordova, change to: cordova plugin add
phonegap local plugin add https://git-wip-us.apache.org/repos/asf/cordova-plugin-device.git
A caveat to this approach is that it makes it a little more challenging to customize the platform specific app code/config outside of what's supported by phonegap/cordova (i.e. screen orientation support).
This gist contains a more complete script for handling a project that does not commit the plugins
and platforms
directories. It provides a mechanism for copying the icons and splashscreen images from www to the platform directories (for iOS and Android), installing plugins, and handling platform specific files that should be added to version control.
Here is another gist which is a Grunt port of the above mentioned bash script. (Thanks to @obie for suggesting grunt).
The answer depends on wich platforms you're developing the phongap app, and if you're following the standard directory structure.
If your project directory structure is standard, then you can start from this gitignore and modify it for your needs.
On a rule of thumb you've to exclude all generated files like the bin/
and gen/
directories.
If you're developing an Android version of your app you should exclude build files too like *.apk
.
All generated files in the android
subdirectory should be excluded too:
Android/bin/
Android/gen/
Android/assets/
I just wanted to leave here my experience with this issue and the approach we finally followed.
In our phonegap project we started to commit all files less the folder /platform using .gitignore file. We thought this way, when the developer cloned the repository the only action remaining to do would be to execute:
phonegap/cordova add platform
But it wasn't. Once the platform was added and we tried to compile, an error appeared and the app didn't install in the device.
Looking the logs, we got some hits that this error was due to plugins. So we decided to reinstall all the plugins we was using in the project and voilá the app run correctly.
So my advice is to save in the repository all the content less the folders platform and plugins. Create and upload to repository a file README with a list of plugins used in the project.
This way, when a developer clone the repository, he/she will have to:
1.- Add the platforms: phonegap/cordova add platform "platform"
2.- Add the plugins: phonegap/cordova plugin add "plugin"
Hope this helps!
Regards.
While it's somewhat personal preference, I went with this (for an android only project). Removing most, but keeping what's custom
ToonPlane/platforms/android/*
!ToonPlane/platforms/android/AndroidManifest.xml
ToonPlane/plugins/*
!ToonPlane/plugins/android.json
!ToonPlane/plugins/fetch.json