shithub: riscv

ref: 5e3b99f280971d1e477c7df850cebbc940d5ab90
dir: /sys/src/cmd/git/add/

View raw version
#!/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 ''