add post update script
This commit is contained in:
parent
6f89721ce6
commit
cb70b22923
|
@ -0,0 +1,110 @@
|
|||
#!/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
|
||||
NOTIFY_EMAILS=`git config --get post-update.email`
|
||||
if [ "$NOTIFY_EMAILS" ];
|
||||
then
|
||||
WHERE=$(readlink -f ../..)
|
||||
( echo Following branches have been updated:
|
||||
for ref
|
||||
do
|
||||
/bin/echo -ne " $ref to "
|
||||
echo `git log --oneline $ref~.. | cut -f1 -d\ `
|
||||
done ) | mail -s "Update to $WHERE on `uname -n`" $NOTIFY_EMAILS
|
||||
fi
|
||||
|
||||
|
||||
|
||||
|
||||
PYTHON=/home/docbow/env/bin/python
|
||||
cd `dirname $0`/../../docbow_project/
|
||||
$PYTHON manage.py syncdb --migrate
|
||||
$PYTHON manage.py collectstatic --noinput
|
||||
$PYTHON manage.py compilemessages
|
||||
if ../docbow.init status >/dev/null; then
|
||||
../docbow.init reload
|
||||
else
|
||||
../docbow.init start
|
||||
fi
|
Loading…
Reference in New Issue