2009-10-02 23:23:52 +05:30
|
|
|
#!/bin/sh
|
|
|
|
|
2009-10-03 13:17:02 +05:30
|
|
|
# get this from your .gitolite.conf; and don't forget this is shell, while
|
|
|
|
# that is perl :-)
|
2009-11-19 17:38:40 +05:30
|
|
|
export GL_ADMINDIR; GL_ADMINDIR=$HOME/.gitolite
|
2009-10-02 23:23:52 +05:30
|
|
|
|
2009-10-03 13:17:02 +05:30
|
|
|
# checkout the master branch to $GL_ADMINDIR
|
|
|
|
GIT_WORK_TREE=$GL_ADMINDIR git checkout -f master
|
|
|
|
|
2009-10-04 15:51:32 +05:30
|
|
|
# remove all fragments. otherwise, you get spurious error messages when you
|
|
|
|
# take away someone's delegation in the main config but the fragment is still
|
|
|
|
# hanging around. The ones that are valid will get re-created anyway
|
|
|
|
rm -rf $GL_ADMINDIR/conf/fragments
|
2009-10-03 13:17:02 +05:30
|
|
|
# collect all the delegated fragments
|
2009-10-04 15:51:32 +05:30
|
|
|
mkdir $GL_ADMINDIR/conf/fragments
|
2009-11-19 17:38:40 +05:30
|
|
|
for br in `git for-each-ref --format='%(refname:short)'`
|
2009-10-03 13:17:02 +05:30
|
|
|
do
|
|
|
|
# skip master (duh!)
|
2009-10-05 16:08:10 +05:30
|
|
|
[ "$br" = "master" ] && continue
|
|
|
|
|
2009-10-03 13:17:02 +05:30
|
|
|
# all other branches *should* contain a file called <branchname>.conf
|
|
|
|
# inside conf/fragments; if so copy it
|
|
|
|
if git show $br:conf/fragments/$br.conf > /dev/null 2>&1
|
|
|
|
then
|
|
|
|
git show $br:conf/fragments/$br.conf > $GL_ADMINDIR/conf/fragments/$br.conf
|
|
|
|
echo "(extracted $br conf; `wc -l < $GL_ADMINDIR/conf/fragments/$br.conf` lines)"
|
|
|
|
else
|
|
|
|
echo " ***** ERROR *****"
|
|
|
|
echo " branch $br does not contain conf/fragments/$br.conf"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
cd $GL_ADMINDIR
|
2009-10-02 23:23:52 +05:30
|
|
|
src/gl-compile-conf
|