shithub: git9

ref: 65e7c353bca28ba6bf0b4cceb387373e853e628a
dir: git9/add

View raw version
#!/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(~ $#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)
			touch $addpath
		rm -f $delpath
	}
}