home.

tagged: git

Git: Seeing the current branch in your command line

You can make a file in your home directory called .bash_profile if it doesn't already exist.
 
This also work on Mac OS X.
 
Then add the following to the bottom.

parse_git_branch() {
    git branch 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/ (\1)/'
}
export PS1="\u@\h \W\[\033[32m\]\$(parse_git_branch)\[\033[00m\] $ "

Then type source ~/.bash_profile.
 
Now your Teminal will tell you git what git branch you're in, if you're in a git repo.

unix git


Git: Setting your username and email

Set your git email and username locally to the repo. I always forget this.

git config user.name bumblebee
git config user.email buzz@buzz.buzz

git


HockeyApp: Generating release notes from git

The problem with uploading to HockeyApp is the release notes are not automatically created.
 
And we can create them by looking at all the git commit logs since the last build.
 
For this to happen we need to know what the last commit was.
 
Although we can specify this in our upload, when we query the builds we can't get this information back. Instead, we'll add the commit SHA to the release notess.
 
Our plan will be
  1. Look at the app versions via HockeyApp's API
  2. Find the lastest version
  3. Look at the release notes that and retrieve our added commit SHA
  4. Make git output all our commit logs since then
  5. Make release notes out of that (including the current git commit)
Here's the entire commented shell script:

# We need an initial bullet point for our list of commit logs
echo -n "* "
# Get the latest app uploads
curl -H "X-HockeyAppToken: $HOCKEYAPP_TOKEN" \
"https://rink.hockeyapp.net/api/2/apps/YOUR_HOCKEYAPP_APP_ID/app_versions?page=1" | \
# Put every property on a separate line
sed 's/,/\n/g' | \
# Remove all the quotation marks
sed 's/"//g' | \
# Look at only the notes properties
grep notes | \
# Look at the first one, i.e. the latest app upload
head -n 1 | \
# Find the commit information at the bottom of the notes
sed -n 's/.*(commit:\([^)]*\)).*/\1/p' | \
# Let's find all the logs since that commit
xargs -I '{}' git log {}..HEAD --pretty=format:'%s' --no-merges | \
# Add a star to each newline to make the list
awk '$0="* "$0'
# The end of the revision log must have the latest commit
# This is so later we can do the above again
echo
echo -n "* (commit:" 
git rev-parse HEAD | xargs echo -n
echo -n ')'

And when we upload to HockeyApp, via travis-ci, we can include it like so:

- bash release_notes_for_hockeyapp.sh > release_notes
- >
  curl
  -F "status=2"
  -F "notify=1"
  -F "notes=<release_notes"
  -F "notes_type=0"
  -F "ipa=@app/build/outputs/apk/YOUR_APK.apk"
  -H "X-HockeyAppToken: $HOCKEYAPP_TOKEN"
  https://rink.hockeyapp.net/api/2/apps/upload


hockeyapp git travis-ci


Git: Subtree tutorial

Git submodules are a pain to deal with. Git subtrees are much nicer.
 
Let's start with your parent repo, and another repo, currently completely separate. The latter of these will be the subtree repo.
 
1) Let's add the repo like a normal repo: git remote add my-subtree git@github.com:your_username/your_repo.git.
 
2) Add the other repo as a subtree: git subtree add --prefix=the_folder/ my-subtree master.
 
That is, git subtree add and then the name of the folder it will live in and finally the repo name and branch.
 
3) Make a change to the files in the_folder and commit. Your parent repo, along with the files in the subtree, will be updated. But the subtree will not.
 
When you want update the files in the subtree repo run git subtree push --prefix=the_folder my-subtree master. And the same command but with pull to pull any new changes.
 
There are more things to learn, like whether you could squash commits and how all this relates to rebasing, but that's the basics.

git


Git: Alias for multiple Github accounts in SSH

Say you have two github accounts. So you have different SSH keys. Github won't know which key relates to which account.
 
However, in your ~/.ssh/config file you can setup an alias that uses the correct IndentityFile to send to github.
 
In that file, put this:

Host new_alias
        Hostname github.com
        User git
        IdentityFile ~/.ssh/id_rsa_new_identity

Now you can use git remote origin git@new_alias:your_username/therepo.git Note the : after the alias name. And the fact you're putting git@ at the start.

git

Page 1 of 3
next