ref: 60b5822dca47196b6bb02279974fcc01fb0f8b0d
dir: /add/
#!/bin/rc -e rfork ne . /sys/lib/git/common.rc usage=' git/add [-r] file ... -r remove file ' gitup add='tracked' del='removed' while(~ $1 -* && ! ~ $1 --){ switch($1){ case -r add='removed' del='tracked' case * usage } shift } if(~ $1 --) shift if(~ $#* 0) usage if(~ $#rel 0) rel='' if(~ $add tracked) files=`$nl{walk -f $gitrel/$*} if not files=`$nl{cd .git/index9/tracked/ && walk -f $gitrel/$*} for(f in $files){ if(! ~ `{cleanname $f} .git/*){ addpath=.git/index9/$add/$f delpath=.git/index9/$del/$f mkdir -p `{basename -d $addpath} mkdir -p `{basename -d $delpath} # We don't want a matching qid, so that # git/walk doesn't think this came from # a checkout. if(! test -e $addpath) if(~ $add 'tracked' || test -e /mnt/git/HEAD/tree/$f) touch $addpath rm -f $delpath } } exit ''