abump.in 2.54 KB
Newer Older
1 2
#!/bin/sh

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

9 10
abuild_ver=@VERSION@
datadir=@datadir@
11

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

18

19
# version bump packages
20
do_bump() {
21
	local p rc=0 name ver section message
Dubiousjim's avatar
Dubiousjim committed
22
	local upgrade="${cvelist:+security }upgrade"
23
	local a
24
	for p; do
25 26
		name=${p%-[0-9]*}
		ver=${p#${name}-}
27

28
		# calculate APKBUILD's path
Natanael Copa's avatar
Natanael Copa committed
29
		if [ "${name#*/}" != "$name" ] && ! [ -d "$APORTSDIR/${name%/*}" ]; then
30 31 32
			error "'$p' should be of form 'foo-1.2.3' or 'main/foo-1.2.3'"
			rc=1; continue
		fi
33 34 35 36 37
		a=$(aports_buildscript "$name" || die "can't find APKBUILD for $name") || { rc=1; continue; }

		# verify APKBUILD
		(
		. "$a" || exit 1
38 39
		[ "$pkgname" = "$name" ] || die "APKBUILD has different \$pkgname for $name"
		type package | grep -q function || die "missing package() for $name"
40
		) || { rc=1; continue; }
41

42 43 44
		(
		set -e

45
		cd "${a%/*}"
Dubiousjim's avatar
Dubiousjim committed
46
		section=${PWD%/*}
47 48
		section=${section##*/}

49
		message="$section/$name: $upgrade to ${ver}${cvelist}"
50 51
		if [ -n "$fixes" ]; then
			message="$message
52 53 54

fixes #${fixes#\#}
"
55
		fi
56
		msg "$message"
57

58
		sed -i -e "s/^pkgver=.*/pkgver=$ver/" \
59 60
			-e "s/^pkgrel=.*/pkgrel=0/" \
			APKBUILD
61

62
		abuild $abuild_opts checksum all
63

64 65 66 67 68
		git add APKBUILD
		git commit -m"$message"
		) || rc=1
	done
	return $rc
69 70
}

71
usage() {
72 73 74 75 76 77 78 79 80 81 82 83
	cat >&2 <<__EOF__
$prog $abuild_ver - bump pkgver in APKBUILDs
Usage: $prog [-s CVE-1,CVE-2,...] [-f ISSUE] [-R|--recursive] [-k|--keep] PKGNAME-1.2.3 ...
Options:
  -s, --security CVE1,CVE-2,...  Security update
  -f, --fixes ISSUE              Fixes ISSUE
  -R, --recursive                Run abuild with -R for recursive building
  -k, --keep                     Run abuild with -k to keep existing packages
  -q, --quiet
  -h, --help                     Show this help

__EOF__
84 85
}

86 87
keep=
recursive="-r"
88 89 90
cvelist=
fixes=

91
[ -n "$APORTSDIR" ] || error "can't locate \$APORTSDIR"
92
git rev-parse 2>/dev/null || die "not in a git tree"
93

94 95 96 97 98 99 100 101
args=`getopt -o s:Rkqh --long security:,recursive,keep,quiet,help -n "$prog" -- "$@"`
if [ $? -ne 0 ]; then
	usage
	exit 2
fi
eval set -- "$args"
while true; do
	case $1 in
Dubiousjim's avatar
Dubiousjim committed
102
		-s|--security) cvelist=" ($2)"; shift;;
103 104 105 106 107 108 109
		-f|--fixes) fixes="$2"; shift;;
		-R|--recursive) recursive="-R";;
		-k|--keep) keep="-k";;
		-q|--quiet) quiet=1;; # suppresses msg
		-h|--help) usage; exit;;
		--) shift; break;;
		*) exit 1;; # getopt error
110
	esac
111
	shift
112
done
113 114 115 116
if [ $# -eq 0 ]; then
	usage
	exit 2
fi
117

118 119
abuild_opts="$recursive $keep"

120
do_bump "$@"
121