apkgrel.in 2.19 KB
Newer Older
1 2
#!/bin/sh

3 4 5 6 7 8
# apkgrel - display or bump pkgrel in APKBUILDs
# Copyright (c) 2012 Natanael Copa <ncopa@alpinelinux.org>
#
# Distributed under GPL-2
#

9 10 11 12 13 14 15 16 17
abuild_ver=@VERSION@
datadir=@datadir@

if ! [ -f "$datadir/functions.sh" ]; then
	echo "$datadir/functions.sh: not found" >&2
	exit 1
fi
. "$datadir/functions.sh"

18 19 20 21 22 23 24 25 26 27 28 29 30

do_show() {
	awk -F= '$1 == "pkgrel" { print $2 }' "$@"
}

do_set() {
	sed -e "/^pkgrel=/s/=.*/=${setto:-0}/" \
		-i "$@"
}

do_add () {
	local f= old=
	for f in "$@"; do
31 32 33 34
		[ -n "$only_clean_git" ] \
			&& [ -n "$(git diff --name-only $f)" ] \
			&& continue
		[ -d "$f" ] && f="$f/APKBUILD"
35 36 37
		old=$(do_show "$f")
		setto=$(($old + 1))
		do_set "$f" || return 1
38
	done
39 40 41 42
}

do_verify() {
	[ -n "$force" ] && return 0
43 44 45 46 47 48 49 50 51
	local f= rc=0
	for f in "$@"; do
		[ -d "$f" ] && f="$f/APKBUILD"
		if ! grep -q '^pkgrel=[0-9]' "$f"; then
			echo "$f: Has no proper pkgrel" >&2
			rc=1
		fi
	done
	return $rc
52 53 54 55 56 57
}

do_nothing() {
	return 0
}

58 59 60 61
usage() {
	cat >&2 <<__EOF__
$prog $abuild_ver - display or bump pkgrel in APKBUILDs
Usage: $prog [-z|--zero] [-a|--add] [-g|--clean-git] [-s|--set NUM] [-t|--test] [-f|--force] DIR or APKBUILD...
62
Options:
63 64
  -z, --zero       Set pkgrel to 0
  -a, --add        Add 1 to current pkgrel
65
  -g, --clean-git  Only operate on APKBUILDs with clean git status (implies --add)
66 67 68 69
  -s, --set NUM    Set pkgrel to NUM
  -t, --test       Only verify that files have a valid pkgrel
  -f, --force      Operate on files without a valid pkgrel
  -h, --help       Show this help
70 71 72 73 74 75

__EOF__
}

cmd=do_show
force=
76 77 78 79 80 81 82 83 84 85 86 87 88
setto=
only_clean_git=

args=`getopt -o zags:tfqh --long zero,add,clean-git,set:,test,force,quiet,help -n "$prog" -- "$@"`
if [ $? -ne 0 ]; then
	usage
	exit 2
fi
eval set -- "$args"
while true; do
	case $1 in
		-z|--zero) setto=0; cmd=do_set;;
		-a|--add) cmd=do_add;;
89 90 91 92
		-g|--clean-git) # verify that we're in a git tree
				git rev-parse 2>/dev/null || die "not in a git tree"
				cmd=do_add
				only_clean_git=1;;
93 94 95 96 97 98 99
		-s|--set) setto=$2; shift; cmd=do_set;;
		-t|--test) cmd=do_nothing;;
		-f|--force) force=1;;
		-q|--quiet) quiet=1;; # noop
		-h|--help) usage; exit;;
		--) shift; break;;
		*) exit 1;; # getopt error
100
	esac
101
	shift
102 103
done
if [ $# -eq 0 ]; then
104 105
	usage
	exit 2
106 107 108 109 110
fi

do_verify "$@" || exit 1
$cmd "$@"