ref: 53a45f053e40abb04d4d72eff89a3cc79e287b2c
dir: /push/
#!/bin/rc -e rfork en . /sys/lib/git/common.rc usage=' git/push [-a] [-u upstream] [-b branch] [-r branch] -a push all branches -b push branch "branch" (default: current branch) -r delete branch "branch" from upstream -u push to remote "upstream" (default: origin) ' gitup remote=() sendall='' remove=() force=() upstream='origin' branch=-b`{git/branch} while(~ $1 -*){ switch($1){ case -u shift upstream=$1 case -a branch=-b`$nl{cd .git/refs/heads && walk -f} case -b shift branch=(-b$1 $branch) case -r shift remove=(-r$1 $remove); case -f force=-f case * usage } shift } if(! ~ $#* 0) usage if(~ $#remote 0) remote=`{git/conf 'remote "'$upstream'".url'} if(~ $#remote 0) remote=$upstream if(~ $#remote 0) die 'no idea where to push' if(~ $#branch 0) die 'no branches' updates=`$nl{git/send $force $branch $remove $remote || die $status} for(ln in $updates){ u=`{echo $ln} refpath=`{echo $u(2) | subst '^refs/heads/' '.git/refs/remotes/'$upstream'/'} switch($u(1)){ case update; mkdir -p `{basename -d $refpath} echo $u(4) > $refpath echo $u(2)^':' $u(3) '=>' $u(4) case delete; echo $u(2)^': removed' rm -f $refpath case uptodate; echo $u(2)^': up to date' } }