cleanup: make work based on location if target not specified

This commit is contained in:
Eric House 2015-08-10 06:23:24 -07:00
parent 8b90f211ed
commit 87e3108296

View file

@ -2,25 +2,21 @@
set -u -e set -u -e
DIRS="" DIR=""
VARIANT=""
usage() { usage() {
[ $# -ge 1 ] && echo "ERROR: $1" [ $# -ge 1 ] && echo "ERROR: $1"
echo "usage: $0 [--dest-dir <dir>]*" echo "usage: $0 [--dir <dir>]"
echo " uses variant parent of CWD as default if not provided"
exit 1 exit 1
} }
while [ $# -ge 1 ]; do while [ $# -ge 1 ]; do
echo "\"$1\"" echo "\"$1\""
case $1 in case $1 in
--variant-name) --dir)
shift shift
VARIANT=$1 DIR="$DIR $1"
;;
--dest-dir)
shift
DIRS="$DIRS $1"
;; ;;
*) *)
usage "unexpected param $1" usage "unexpected param $1"
@ -29,12 +25,26 @@ while [ $# -ge 1 ]; do
shift shift
done done
for DIR in $DIRS; do if [ -z "$DIR" ]; then
for FILE in $(find $DIR -type f); do while :; do
if git ls-files $FILE --error-unmatch 2>/dev/null; then WD=$(pwd)
echo "skipping $FILE; it's under version control within this variant" if [ "/" = "$WD" ]; then
echo "reached / without finding AndroidManifest.xml"
exit 1
elif [ -e ${WD}/AndroidManifest.xml ]; then
DIR=$WD
break
else else
rm $FILE cd ..
fi fi
done done
fi
for FILE in $(find $DIR -type f); do
if git ls-files $FILE --error-unmatch 2>/dev/null; then
echo "skipping $FILE; it's under version control within this variant"
else
echo "removing $FILE"
rm $FILE
fi
done done