ref: 5e3b99f280971d1e477c7df850cebbc940d5ab90
dir: /sys/src/cmd/git/add/
#!/bin/rc -e rfork ne . /sys/lib/git/common.rc gitup flagfmt='r:remove'; args='file ...' eval `''{aux/getflags $*} || exec aux/usage add='tracked' del='removed' if(~ $remove 1){ add='removed' del='tracked' } if(~ $#* 0) exec aux/usage paths=`$nl{cleanname -d $gitrel $*} if(~ $add tracked) files=`$nl{walk -f $paths} if not files=`$nl{cd .git/index9/tracked/ && walk -f $paths} for(f in $files){ if(! ~ `$nl{cleanname $f} .git/*){ addpath=.git/index9/$add/$f delpath=.git/index9/$del/$f mkdir -p `$nl{basename -d $addpath} mkdir -p `$nl{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 $gitfs/HEAD/tree/$f) touch $addpath rm -f $delpath } } exit ''