diff options
Diffstat (limited to 'backport')
-rwxr-xr-x | backport | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/backport b/backport new file mode 100755 index 0000000..4941aa0 --- /dev/null +++ b/backport @@ -0,0 +1,115 @@ +#!/bin/bash + +# Script to automate backporting for CRAN +# Creates a source package and binary packages for the following architecture +ARCH=i386 +export ARCH + +# R version against which the software is compiled +Rversion=3.2.3 +reposversion="cran3" + +# Where the buildresults should be stored +rcrandir=/home/jranke/svn/website/www/ranke/r-cran + +# Author: Johannes Ranke <jranke@uni-bremen.de> + +# Preconditions: +# - up to date R version specified above, for packages depending on R +# - sudo and pbuilder configuration (see README) +# - sid sources in /etc/apt/sources/list +# - cdbs installed (and maybe more) +# - shell variables DEBEMAIL and DEBFULLNAME + +usage() +{ +echo "Usage: ./backport [options] sourcepackage squeeze|wheezy|jessie" +echo "Options:" +echo " -n Skip apt-get update/upgrade and pbuilder update" +} + +update=true +while getopts ":n" flag; do + case $flag in + n) + update=false + ;; + \?) + echo "Invalid option: -$OPTARG" >&2 + ;; + esac + shift $((OPTIND-1)) +done + +# Check for number of arguments +if [ $# -lt 2 ]; then usage; exit 1; fi +pkg=$1 +DIST=$2 + +# Validate distribution argument +if [ $DIST != "squeeze" ] && [ $DIST != "wheezy" ] && [ $DIST != "jessie" ]; then usage; exit 1; fi +export DIST + +# Set required r-base-dev version for packages build-depending on R +rbasedev="r-base-dev (>= $Rversion)" + +# Remove previously extracted sources +if [ -d $pkg-* ] +then + sudo rm -rf `ls -d $pkg-*` +fi + +# Get current source from unstable +if [ "$update" = true ] +then + sudo apt-get update + sudo apt-get upgrade +fi +sudo apt-get source $pkg + +# Copy sources to $DIST directory to enable parallel builds +mkdir -p $DIST +cp -r $pkg-* $DIST + +# Go to package building directory +cd $DIST/$pkg-* + +# Determine the version of the Debian package +oldversion=`dpkg-parsechangelog | grep ^Version | cut -f2 -d " "` +cranversion=$oldversion"~"$DIST"cran.0" + +echo Old version is $oldversion +echo CRAN version is $cranversion + +# Add new version to changelog +dch -v "${cranversion}" --force-distribution -D $DIST-cran -b "Backport from Debian unstable to Debian $DIST" + +# Adapt build dependency on r-base-dev if present +if grep -q "^Build-Depends.*r-base-dev" debian/control +then + echo "Lowering Build-Depends to $rbasedev" + ssed -i -R "/^Build-Depends/s/r-base-dev \(>= .*?\)/$rbasedev/" debian/control + ssed -i -R "/^Build-Depends-Indep/s/r-base-dev \(>= .*?\)/$rbasedev/" debian/control + + dch -a "debian/control: adapt build dependencies on r-base-dev to current backport" +fi + +# Check for a script doing modifications required for backporting +script=../$pkg-reverts.sh + +if [ -f $script ]; then source $script; fi + +if [ "$update" = true ] +then + sudo -E pbuilder update +fi +sudo -E pdebuild --debbuildopts '-sa' \ + --buildresult $rcrandir/$DIST-cran3/ \ + -- --distribution $DIST --basetgz /var/cache/pbuilder/$DIST-$ARCH-base.tgz \ + --aptcache /var/cache/pbuilder/$DIST-$ARCH/aptcache \ + --buildplace /var/cache/pbuilder/$DIST-$ARCH/build +if [ $? -ne 0 ]; then + exit +fi + +cd .. |