Created
January 25, 2016 12:14
-
-
Save socketz/81116217337626814411 to your computer and use it in GitHub Desktop.
post-update file for git push deployment
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