Created
March 26, 2012 20:12
-
-
Save chexov/2209325 to your computer and use it in GitHub Desktop.
git-post-update.sh
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/sh | |
# | |
# This hook does two things: | |
# | |
# 1. update the "info" files that allow the list of references to be | |
# queries over dumb transports such as http | |
# | |
# 2. if this repository looks like it is a non-bare repository, and | |
# the checked-out branch is pushed to, then update the working copy. | |
# This makes "push" function somewhat similarly to darcs and bzr. | |
# | |
# To enable this hook, make this file executable by "chmod +x post-update". | |
git update-server-info | |
is_bare=$(git config --get --bool core.bare) | |
if [ -z "$is_bare" ] | |
then | |
# for compatibility's sake, guess | |
git_dir_full=$(cd $GIT_DIR; pwd) | |
case $git_dir_full in */.git) is_bare=false;; *) is_bare=true;; esac | |
fi | |
update_wc() { | |
ref=$1 | |
echo "Push to checked out branch $ref" >&2 | |
if [ ! -f $GIT_DIR/logs/HEAD ] | |
then | |
echo "E:push to non-bare repository requires a HEAD reflog" >&2 | |
exit 1 | |
fi | |
if (cd $GIT_WORK_TREE; git diff-files -q --exit-code >/dev/null) | |
then | |
wc_dirty=0 | |
else | |
echo "W:unstaged changes found in working copy" >&2 | |
wc_dirty=1 | |
desc="working copy" | |
fi | |
if git diff-index --cached HEAD@{1} >/dev/null | |
then | |
index_dirty=0 | |
else | |
echo "W:uncommitted, staged changes found" >&2 | |
index_dirty=1 | |
if [ -n "$desc" ] | |
then | |
desc="$desc and index" | |
else | |
desc="index" | |
fi | |
fi | |
if [ "$wc_dirty" -ne 0 -o "$index_dirty" -ne 0 ] | |
then | |
new=$(git rev-parse HEAD) | |
echo "W:stashing dirty $desc - see git-stash(1)" >&2 | |
( trap 'echo trapped $$; git symbolic-ref HEAD "'"$ref"'"' 2 3 13 15 ERR EXIT | |
git update-ref --no-deref HEAD HEAD@{1} | |
cd $GIT_WORK_TREE | |
git stash save "dirty $desc before update to $new"; | |
git symbolic-ref HEAD "$ref" | |
) | |
fi | |
# eye candy - show the WC updates :) | |
echo "Updating working copy" >&2 | |
(cd $GIT_WORK_TREE | |
git diff-index -R --name-status HEAD >&2 | |
git reset --hard HEAD) | |
} | |
if [ "$is_bare" = "false" ] | |
then | |
active_branch=`git symbolic-ref HEAD` | |
export GIT_DIR=$(cd $GIT_DIR; pwd) | |
GIT_WORK_TREE=${GIT_WORK_TREE-..} | |
for ref | |
do | |
if [ "$ref" = "$active_branch" ] | |
then | |
update_wc $ref | |
fi | |
done | |
fi |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment