Created
November 27, 2009 00:43
-
-
Save dchest/243747 to your computer and use it in GitHub Desktop.
Git post-update hook to checkout working copy and publish it with jekyll (put it into .git/hooks and chmod +x post-update)
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 |
@gbraad Thanks. The script was based on template from some old version of git, which was using "git-command". Updated.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
http://utsl.gen.nz/git/post-update
git-config does not always work