summaryrefslogtreecommitdiff
path: root/abump.in
blob: a344780a19ad3a392d7e2debb8938fe4575eb346 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
#!/bin/sh

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

abuild_ver=@VERSION@
datadir=@datadir@

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


# version bump packages
do_bump() {
	local p rc=0 name ver section message
	local upgrade="${cvelist:+security }upgrade"
	local a
	for p; do
		name=${p%-[0-9]*}
		ver=${p#${name}-}

		# calculate APKBUILD's path
		if [ "${name#*/}" != "$name" ] && ! [ -d "$APORTSDIR/${name%/*} ]; then
			error "'$p' should be of form 'foo-1.2.3' or 'main/foo-1.2.3'"
			rc=1; continue
		fi
		a=$(aports_buildscript "$name" || die "can't find APKBUILD for $name") || { rc=1; continue; }

		# verify APKBUILD
		(
		. "$a" || exit 1
		[ "$pkgname" = "$name" ] || die "$name: APKBUILD has different \$pkgname"
		type package | grep -q function || die "$name: missing package()"
		case $(apk version --test "$pkgver" "$ver") in
		'=') die "$pkgname: already at version $pkgver";;
		'>') die "$pkgname: already at newer version $pkgver";;
		'<') exit 0;;
		*) exit 1;;
		esac
		) || { rc=1; continue; }

		(
		set -e

		cd "${a%/*}"
		section=${PWD%/*}
		section=${section##*/}

		message="$section/$name: $upgrade to ${ver}${cvelist}"
		if [ -n "$fixes" ]; then
			message="$message

fixes #${fixes#\#}
"
		fi
		echo "$message"

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

		abuild $abuild_opts checksum all

		git add APKBUILD
		git commit -m"$message"
		) || rc=1
	done
	return $rc
}

usage() {
	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__
}

keep=
recursive="-r"
cvelist=
fixes=

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

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
		-s|--security) cvelist=" ($2)"; shift;;
		-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
	esac
	shift
done
if [ $# -eq 0 ]; then
	usage
	exit 2
fi

abuild_opts="$recursive $keep"

do_bump "$@"