ref: b4721715066c1a28d0ef2b29b97652316959c101
dir: /branch/
#!/bin/rc -e
rfork en
. /sys/lib/git/common.rc
usage='
git/branch [-cdsu] [-b base] [new]
-b base base new branch on "base" (default: current branch)
-d delete a branch
-s create a branch but stay on current one
'
gitup
stay=()
create=()
delete=()
base=()
while(~ $1 -* && ! ~ $1 --){
switch($1){
case -c; create=true
case -s; stay=true
case -b; shift; base=$1
case -d; delete=true
case -u; update=true
case *
usage
}
shift
}
if(~ $1 --) shift
if(~ $#* 0){
awk '$1=="branch"{print $2}' < /mnt/git/ctl
exit
}
if(! ~ $#* 1)
usage
if(~ $1 refs/heads/*)
new=$1
if not if(~ $1 heads/*)
new=refs/$1
if not
new=refs/heads/$1
if (~ $#base 1)
base=`{git/query $base}
if not if(test -e .git/$new)
base=`{git/query $new}
if not
base=`{git/query HEAD}
if(! ~ $#delete 0){
rm -f .git/$new
exit
}
modified=`$nl{git/query -c HEAD $base | grep '^[^-]' | sed 's/^..//'}
deleted=`$nl{git/query -c HEAD $base | grep '^-' | sed 's/^..//'}
if(! git/walk -q $modified $deleted)
die 'uncommited changes'
if(! ~ $#create 0){
if(! test -e .git/$new)
die 'branch does not exist:' $new
}
if not{
commit=`{git/query $base || die 'branch does not exist:' $base}
echo updating $new to $commit
echo $commit > .git/$new
}
if(! ~ $#stay 0)
exit
if(! ~ $#modified 0){
basedir=`{git/query -p $base}
for(m in $modified){
d=`{basename -d $m}
mkdir -p $d
mkdir -p .git/index9/tracked/$d
# Modifications can turn a file into
# a directory, or vice versa, so we
# need to delete and copy the files
# over. If we're checking out a
a=`{test -f $m && echo file || echo dir}
b=`{test -f $basedir/tree/$m && echo file || echo dir}
if(! ~ $a $b){
rm -rf $m
rm -rf .git/index9/tracked/$m
}
if(test -f $basedir/tree/$m){
cp $basedir/tree/$m $m
walk -eq $m > .git/index9/tracked/$m
}
}
}
if(! ~ $#deleted 0){
rm -f $deleted
rm -f .git/index9/tracked/$deleted
}
echo ref: $new > .git/HEAD