Skip to content
meganleewebb edited this page Apr 30, 2012 · 7 revisions

#Git Guide For K-9

Want to contribute to K-9, but never used git before? Or just need a refresher? Or want to know how the K-9 leaders want things done? Then this guide is for you!

##Notice This page first created 20 October 2011 and may contain errors. If you have trouble with it, feel free to contact me, or change it if needed. You can also join us on IRC on #k-9 on irc.freenode.net, or via webchat. I created this guide as a reference for myself almost as much as for anyone else because I've only been using git for 12 days now.

##Create GitHub account First, set up a GitHub account if you don't already have one at https://github.com/signup/free.

##Set Up Git Here are instructions for setting up git for Linux, OSX, and Windows.

The Linux page covers installing with Synaptic (Debian/Ubuntu), but also includes important set up instructions for any distribution. Use whatever package manager your distribution uses (Gentoo example: $ sudo emerge -av dev-vcs/git).

##Set Up Your Fork

Fork K-9 by going to https://github.com/k9mail/k-9/ and clicking on "Fork" towards the top right. In a few seconds you'll have your own repo, but it's all still just online.

To clone your repo locally, enter

$ git clone [email protected]:USERNAME/k-9.git

This will create a directory called "k-9" in your current directory. USERNAME is your github username (most occurances of code in CAPS in this guide is meant as a variable, with the exceptions of HEAD which is git-specific and the bash code at the end of this document). In order for your code to keep up with K-9's development, you need to configure another remote. The default remote named "origin" points to your fork on GitHub. To keep track of the original repo, add a remote named "upstream":

$ cd k-9
$ git remote add upstream git://github.com/k9mail/k-9.git
$ git fetch upstream

Everything is now set up!

See http://help.github.com/fork-a-repo/ for more information.

##Start Coding With Git

Be sure to check out the K-9 Code Style. It will save you from being told to make a whole bunch of changes that don't actually affect how the program works!

###Working with branches

Git starts out in the master branch, but this should be left alone in order to be updated with K-9's master branch. Each feature or bug fix you do should get it's own branch. As cketti (someone who might be approving your pull requests) told me, "if in doubt, create a branch :)". So, to create a new branch named NEWFEATURE enter

$ git branch NEWFEATURE  

and to switch to that branch enter

$ git checkout NEWFEATURE

You can also combine the above with

$ git checkout -b NEWFEATURE

Now any changes you make will be isolated to this branch. Running $ git branch will show you what branches you have, and which one is active. Or if you're using Bash, see the end of this page to always know what branch is active.

###Compiling and installing

You do have the Android SDK already, don't you? It doesn't work on my pure 64 bit Gentoo system (though it may if you have multilib setup), so I run it in a 32 bit chroot (and have git set up in both environments).

To compile K-9 enter

$ ant debug

If it compiles, you can install it with

$ adb install bin/K9-debug.apk

or reinstall it with

$ adb install -r bin/K9-debug.apk

You'll need to make sure your Android device is set to USB debugging (Settings -> Applications -> Development -> USB debugging).

If you've made any changes to files outside of src/ then you probably need to $ ant clean before you can compile it (definitely true for changes to files in res/)

Note: Android apps are signed by the publisher (in K-9's case, obra), and the K9-debug.apk is not signed by him, so an install of your build will fail if a released version of K-9 is installed. You can use an emulator, or remove K-9 from your phone first (and probably all of it's data). If you have root on your phone then you can backup your data which is in /data/data/com.fsck.k9. Now you can (re)install your own builds of K-9. Alternatively, you can install a completely separate version of K-9 by always doing ./tools/build-beta debug instead of ant debug (requires perl to be installed in your path).

###Committing changes

Once you're happy, you need to add and commit your changes. Make sure not to add any files that were changed just for you (like build.properties, for example -- use local.properties instead) to be able to compile it on your system.

To add changed files enter

$ git add --interactive

The staged column shows how many changes have been added. The unstaged column shows how many changes have not been added. Enter u to update, then to add files 1, 2 and 4 enter 1 2 4, leaving 3 unstaged. Press enter again, then q to quit.

A shortcut to add all changed files is

$ git add -u

If you need to add new files enter

$ git add FILE1 FILE2 ...

Once you're ready to commit these changes enter

$ git commit

and enter a descriptive summary of your modifications and save the file.

You can also combine "git add --interactive" and "git commit" with

$ git commit --interactive

Once a commit is done (i.e. you should be really happy with it) you can push it to your fork with

$ git push origin NEWFEATURE

Now everyone has access to your new feature or bug fix! But if you actually want it included with K-9 and not just your fork, you need to send a pull request.

###Send A Pull Request Sending a pull request lets the main developers of K-9 know that you think you have something useful to add. On your forked project's main page you need to change the current branch to "NEWFEATURE", then click on "Pull Request". Give a descriptive title to the request, and any more necessary information in the body. Click on "Commits" and "Files Changed" to review what is being sent, and then back to "Preview Discussion". When you're satisfied, click on "Send pull request" and the people to the right will be notified of your contribution. Someone might comment on things that need to be changed, or clarified, or anything else. You'd then go back to your branch, make the changes, commit it (with a new note on what this commit changes) and push it to your fork. This new commit will automatically show up on the pull request.

###Updating your master to K-9's master

So, you've forked K-9 and cloned your fork, maybe have your own branches, but you haven't changed your master, and some time later K-9 is ahead of your master. Now you need your own master to be up to date so you can make changes where code has been changed by others (or even a pull
request of yours that was merged!).

First, make sure you're in master:

$ git checkout master

Next, fetch it:

$ git fetch upstream

Now, merge the changes from upstream/master to your local master:

$ git merge upstream/master

Finally, update your repo's master:

$ git push origin master

Now you can create new branches from the updated master. Yay!

##Some Other Useful Commands

To merge branch NEWFEATURE with branch OTHER:

$ git checkout OTHER
$ git merge NEWFEATURE

To delete a branch:

$ git branch -d NEWFEATURE

To delete a branch from GitHub:

$ git push origin :NEWFEATURE  

To merge the last two commits together (only if you haven't pushed your commit, or BadThingsWillHappen):

$ git rebase -i HEAD~2

or to update a commit (same warning):

$ git commit --amend  

To save your work when you're not ready to make a commit:

$ git stash save

See http://ariejan.net/2008/04/23/git-using-the-stash/ on what to do with the stash.

##Bash Prompt Listing Current Branch It'd be nice to always know what branch you're working on. If your shell is Bash, you can take it from

ashley@tantrum k-9 $ 

to

ashley@tantrum k-9 (master) $ 

(where ashley@tantrum is green, k-9 and $ are blue, and (master) is yellow) by entering the following in your ~/.bashrc file

function parse_git_branch {
  ref=$(git symbolic-ref HEAD 2> /dev/null) || return
  echo "("${ref#refs/heads/}") "
}
PS1='\ [\033[01;32m\]\u@\h\ [\033[01;34m\] \W \ [\033[01;33m\]$(parse_git_branch)\ [\033[01;34m\]\$\ [\033[00m\] '

(but remove all the spaces in PS1 between \ and [, as the wiki thinks it's the start of [\LaTeX] input)

Clone this wiki locally