blob: a779a26b68edef7184f5f45d1a9864baab4a9c20 [file] [log] [blame]
Harald Welteee497f22017-10-03 16:54:41 +08001#!/bin/sh
2VERSION=$1
3REL=$2
4
5if [ "z$REL" = "z" ]; then
6 echo "No REL value specified, defaulting to 'patch' release"
Pau Espin Pedrol941fd9b2018-08-30 12:42:37 +02007 REL="patch"
Harald Welteee497f22017-10-03 16:54:41 +08008fi
9
Pau Espin Pedrolcf8497c2018-08-30 12:56:53 +020010ALLOW_NO_LIBVERSION_CHANGE="${ALLOW_NO_LIBVERSION_CHANGE:-0}"
Pau Espin Pedrol1a72baf2018-08-30 13:50:33 +020011ALLOW_NO_LIBVERSION_DEB_MATCH="${ALLOW_NO_LIBVERSION_DEB_MATCH:-0}"
Pau Espin Pedrolc5527f02019-08-07 14:40:08 +020012# Test stuff but don't modify stuff:
13DRY_RUN="${DRY_RUN:-0}"
Pau Espin Pedrol1a72baf2018-08-30 13:50:33 +020014
15libversion_to_deb_major() {
16 libversion="$1"
17 current="$(echo "$libversion" | cut -d ":" -f 1)"
18 #revision="$(echo "$libversion" | cut -d ":" -f 2)"
19 age="$(echo "$libversion" | cut -d ":" -f 3)"
20 major="$(expr "$current" - "$age")"
21 echo "$major"
22}
Pau Espin Pedrolcf8497c2018-08-30 12:56:53 +020023
Pau Espin Pedrol6d575562019-08-07 23:39:32 +020024# Make sure that depedency requirement versions match in configure.ac vs debian/control.
25#eg: "PKG_CHECK_MODULES(LIBOSMOCORE, libosmocore >= 1.1.0)" vs "libosmocore-dev (>= 1.0.0),"
26check_configureac_debctrl_deps_match() {
27 configureac_list=$(grep -e "PKG_CHECK_MODULES" "${GIT_TOPDIR}/configure.ac" | cut -d "," -f 2 | tr -d ")" | tr -d " " | sed "s/>=/ /g")
28 echo "$configureac_list" | \
29 { return_error=0
30 while read -r dep ver; do
31
32 debctrl_match="$(grep -e "${dep}-dev" ${GIT_TOPDIR}/debian/control | grep ">=")"
33 debctrl_match_count="$(echo "$debctrl_match" | grep -c ">=")"
34 if [ "z$debctrl_match_count" != "z0" ]; then
35 #echo "Dependency <$dep, $ver> from configure.ac matched in debian/control! ($debctrl_match_count)"
36 if [ "z$debctrl_match_count" != "z1" ]; then
37 echo "WARN: configure.ac <$dep, $ver> matches debian/control $debctrl_match_count times, manual check required!"
38 else # 1 match:
39 parsed_match=$(echo "$debctrl_match" | tr -d "(" | tr -d ")" | tr -d "," | tr -d " " | sed "s/>=/ /g")
40 debctrl_dep=$(echo "$parsed_match" | cut -d " " -f 1 | sed "s/-dev//g")
41 debctrl_ver=$(echo "$parsed_match" | cut -d " " -f 2)
42 if [ "z$dep" != "z$debctrl_dep" ] || [ "z$ver" != "z$debctrl_ver" ]; then
43 echo "ERROR: configure.ac <$dep, $ver> does NOT match debian/control <$debctrl_dep, $debctrl_ver>!"
44 return_error=1
45 #else
46 # echo "OK: configure.ac <$dep, $ver> matches debian/control <$debctrl_dep, $debctrl_ver>"
47 fi
48 fi
49 fi
50 done
51 if [ $return_error -ne 0 ]; then
52 exit 1
53 fi
54 }
55
56 # catch and forward exit from pipe subshell "while read":
57 if [ $? -ne 0 ]; then
58 echo "ERROR: exiting due to previous errors"
59 exit 1
60 fi
61 echo "OK: dependency specific versions in configure.ac and debian/control match"
62}
63
Pau Espin Pedrol3a8d5d32019-08-08 12:59:40 +020064# Make sure that patches under debian/patches/ apply:
65check_debian_patch_apply() {
66 if [ ! -d "${GIT_TOPDIR}/debian/patches" ]; then
67 return
68 fi
69 for patch in ${GIT_TOPDIR}/debian/patches/*.patch; do
70 git apply --check $patch
71 if [ $? -ne 0 ]; then
72 echo "ERROR: patch no longer applies! $patch"
73 exit 1
74 else
75 echo "OK: patch applies: $patch"
76 fi
77 done
78}
79
Harald Welteee497f22017-10-03 16:54:41 +080080BUMPVER=`command -v bumpversion`
Pau Espin Pedrol1a72baf2018-08-30 13:50:33 +020081GIT_TOPDIR="$(git rev-parse --show-toplevel)"
Harald Welteee497f22017-10-03 16:54:41 +080082NEW_VER=`bumpversion --list --current-version $VERSION $REL --allow-dirty | awk -F '=' '{ print $2 }'`
83LIBVERS=`git grep -n LIBVERSION | grep '=' | grep am | grep -v LDFLAGS`
Pau Espin Pedrol01dd5702018-05-03 15:01:47 +020084MAKEMOD=`git diff --cached -GLIBVERSION --stat | grep Makefile.am`
Harald Welteee497f22017-10-03 16:54:41 +080085ISODATE=`date -I`
86
87if [ "z$BUMPVER" = "z" ]; then
88 echo Unable to find 'bumpversion' command.
89 exit 1
90fi
91
92if [ "z$NEW_VER" = "z" ]; then
93 echo "Please fix versioning to match http://semver.org/ spec (current is $VERSION) before proceeding."
94 exit 1
95fi
96
97echo "Releasing $VERSION -> $NEW_VER..."
98
Pau Espin Pedrol6d575562019-08-07 23:39:32 +020099check_configureac_debctrl_deps_match
Pau Espin Pedrol3a8d5d32019-08-08 12:59:40 +0200100check_debian_patch_apply
Pau Espin Pedrol6d575562019-08-07 23:39:32 +0200101
Pau Espin Pedrol01dd5702018-05-03 15:01:47 +0200102if [ "z$LIBVERS" != "z" ]; then
Pau Espin Pedrolcf8497c2018-08-30 12:56:53 +0200103 if [ "z$MAKEMOD" = "z" ] && [ "z$ALLOW_NO_LIBVERSION_CHANGE" = "z0" ]; then
104 echo "ERROR: Before releasing, please modify some of the libversions: $LIBVERS"
Pau Espin Pedrol01dd5702018-05-03 15:01:47 +0200105 echo "You should NOT be doing this unless you've read and understood following article:"
106 echo "https://www.gnu.org/software/libtool/manual/html_node/Updating-version-info.html#Updating-version-info"
Pau Espin Pedrol0b0f9082018-05-02 15:58:37 +0200107 exit 1
Harald Welteee497f22017-10-03 16:54:41 +0800108 fi
Pau Espin Pedrol1a72baf2018-08-30 13:50:33 +0200109 if [ "z$ALLOW_NO_LIBVERSION_DEB_MATCH" = "z0" ]; then
110 echo "$LIBVERS" | while read -r line; do
Pau Espin Pedrol2c281292019-08-06 17:58:22 +0200111 libversion=$(echo "$line" | cut -d "=" -f 2 | tr -d "[:space:]")
Pau Espin Pedrol1a72baf2018-08-30 13:50:33 +0200112 major="$(libversion_to_deb_major "$libversion")"
113 file_matches="$(find "${GIT_TOPDIR}/debian" -name "lib*${major}.install" | wc -l)"
114 if [ "z$file_matches" = "z0" ]; then
115 echo "ERROR: Found no matching debian/lib*$major.install file for LIBVERSION=$libversion"
116 exit 1
117 elif [ "z$file_matches" = "z1" ]; then
118 echo "OK: Found matching debian/lib*$major.install for LIBVERSION=$libversion"
119 else
120 echo "WARN: Found $file_matches files matching debian/lib*$major.install for LIBVERSION=$libversion, manual check required!"
121 fi
Pau Espin Pedrolc4228d12019-08-07 14:41:44 +0200122
Pau Espin Pedrol1a72baf2018-08-30 13:50:33 +0200123 control_matches="$(grep -e "Package" "${GIT_TOPDIR}/debian/control" | grep "lib" | grep "$major$" | wc -l)"
124 if [ "z$control_matches" = "z0" ]; then
125 echo "ERROR: Found no matching Package lib*$major in debian/control for LIBVERSION=$libversion"
126 exit 1
127 elif [ "z$control_matches" = "z1" ]; then
128 echo "OK: Found 'Package: lib*$major' in debian/control for LIBVERSION=$libversion"
129 else
130 echo "WARN: Found $file_matches files matching 'Package: lib*$major' in debian/control for LIBVERSION=$libversion, manual check required!"
131 fi
Pau Espin Pedrolc4228d12019-08-07 14:41:44 +0200132
133 dhstrip_lib_total="$(grep -e "dh_strip" "${GIT_TOPDIR}/debian/rules" | grep "\-plib" | wc -l)"
134 dhstrip_lib_matches="$(grep -e "dh_strip" "${GIT_TOPDIR}/debian/rules" | grep "\-plib" | grep "$major" | wc -l)"
135 if [ "z$dhstrip_lib_total" != "z0" ]; then
136 if [ "z$dhstrip_lib_matches" = "z0" ] ; then
137 echo "ERROR: Found no matching 'dh_strip -plib*$major' line in debian/rules for LIBVERSION=$libversion"
138 exit 1
139 elif [ "z$dhstrip_lib_total" = "z1" ]; then
140 echo "OK: Found 'dh_strip -plib*$major' in debian/rules for LIBVERSION=$libversion"
141 else
142 echo "WARN: Found $dhstrip_lib_matches/$dhstrip_lib_total dh_strip matches 'dh_strip -plib*$major' in debian/rules for LIBVERSION=$libversion, manual check required!"
143 fi
144 fi
Pau Espin Pedrol1a72baf2018-08-30 13:50:33 +0200145 done
146 # catch and forward exit from pipe subshell "while read":
147 if [ $? -ne 0 ]; then
148 exit 1
149 fi
150 fi
Pau Espin Pedrolc5527f02019-08-07 14:40:08 +0200151 if [ "z$DRY_RUN" != "z0" ]; then
152 exit 0
153 fi
Pau Espin Pedrol01dd5702018-05-03 15:01:47 +0200154 if [ -f "TODO-RELEASE" ]; then
155 grep '#' TODO-RELEASE > TODO-RELEASE.clean
156 mv TODO-RELEASE.clean TODO-RELEASE
157 git add TODO-RELEASE
158 fi
Harald Welteee497f22017-10-03 16:54:41 +0800159fi
Pau Espin Pedrolc5527f02019-08-07 14:40:08 +0200160
161if [ "z$DRY_RUN" != "z0" ]; then
162 exit 0
163fi
Pau Espin Pedrol01dd5702018-05-03 15:01:47 +0200164gbp dch --debian-tag='%(version)s' --auto --meta --git-author --multimaint-merge --ignore-branch --new-version="$NEW_VER"
Harald Welteee497f22017-10-03 16:54:41 +0800165dch -r -m --distribution "unstable" ""
Pau Espin Pedrol01dd5702018-05-03 15:01:47 +0200166git add debian/changelog
Harald Welteee497f22017-10-03 16:54:41 +0800167bumpversion --current-version $VERSION $REL --tag --commit --tag-name $NEW_VER --allow-dirty
Pau Espin Pedrolbf819322018-05-03 15:25:11 +0200168git commit --amend # let the user add extra information to the release commit.
Harald Welteee497f22017-10-03 16:54:41 +0800169git tag -s $NEW_VER -f -m "Release v$NEW_VER on $ISODATE."
170echo "Release $NEW_VER prepared, tagged and signed."