#
# - automate builds with sbuild and dinstall the result
#
-# Copyright (c) 2008 martin f. krafft <madduck@debian.org>
+# Copyright (c) 2008–2010 martin f. krafft <madduck@debian.org>
# Released under the terms of the Artistic Licence 2.0.
#
set -eu
ME="${0##*/}"
BUILDDIR="$(mktemp -dt $ME.XXXXXXXX)"
-trap "cd /tmp && rm -r '$BUILDDIR'" 0
+cleanup() {
+ cd /tmp && rm -r "$BUILDDIR"
+ trap - 1 2 3 4 5 6 7 8 10 11 12 13 14 15
+}
+trap cleanup 1 2 3 4 5 6 7 8 10 11 12 13 14 15
BUNDLE_DIR="${TMPDIR:-/tmp}"
TARGET_DIR="$PWD"
print_bundle_location() {
echo "Bundle available at $@ ."
}
+postbuild() {
+ :
+}
KEYID=
binonly=0
sbuild_args=
+sbuild_args_sourceful=
schangesfile=
arch=
for opt in "$@"; do
-h|--help) usage; exit 0;;
-V|--version) about; exit 0;;
--arch=*) arch="${opt#--arch=}";;
+ -D) sbuild_args="${sbuild_args:+$sbuild_args }$opt";;
-sa) sbuild_args="${sbuild_args:+$sbuild_args }--force-orig-source";;
-B) binonly=1;;
--*) sbuild_args="${sbuild_args:+$sbuild_args }$opt";;
exit 1
fi
-[ -z "$arch" ] && arch="$DEB_BUILD_ARCH"
-
dist="$(sed -ne 's,Distribution: ,,p' "$schangesfile")"
schangesfile_basename="${schangesfile##*/}"
packagename="${schangesfile_basename%%_*}"
packagenameversion="${schangesfile_basename%_*}"
+debversion="${packagenameversion#*_}"
+upstream_version="${debversion%-*}"
dscfile_basename="$packagenameversion".dsc
case "$schangesfile" in
dcmd cp "${schangesfile##*/}" "$BUILDDIR"
schangesfile="$schangesfile_basename"
+OLDPWD="$PWD"
cd "$BUILDDIR"
dcmd "$dscfile_basename" | while read f; do
test -f "$f" && continue
case "$f" in
- *.tar.gz) apt-get --tar-only --only-source source "$packagename";;
+ *.tar.gz|*.tar.bz2|*.tar.lzma|*.tar.xz)
+ if [ -f "$OLDPWD/$f" ]; then
+ echo "I: using existing tarball for $upstream_version…" >&2
+ cp $OLDPWD/$f $f
+ else
+ last_version="$(apt-cache madison $packagename | sed -rne "s,.+(\<${upstream_version}[^[:space:]]+).*,\1,p")"
+ echo "I: fetching missing tarball for $upstream_version (from $last_version)…" >&2
+ if ! apt-get --tar-only --only-source source "${packagename}=${last_version}"; then
+ echo "E: I do not know how to obtain the file: $f" >&2
+ exit 1
+ fi
+ fi
+ ;;
*)
echo "E: I do not know how to obtain the file: $f" >&2
exit 1
esac
done
-[ "$binonly" = 0 ] && sbuild_args="${sbuild_args:+$sbuild_args }--source --arch-all"
+rm $schangesfile
+unset schangesfile
+
+[ -z "$arch" ] && arch="$DEB_BUILD_ARCH"
+
+target_arch="$(sed -ne 's,^Architecture: ,,p' $dscfile_basename)"
+case "$binonly/$target_arch" in
+ 1/all)
+ echo "E: cannot build arch:all packages with -B." >&2
+ exit 1
+ ;;
+ 0/all) arch=all;;
+ */any)
+ arch="$(schroot -l | sed -rne 's,^sid-([^-]+).*,\1,p' | uniq | tr '\n' ' ')"
+ ;;
+esac
-sbuild $sbuild_args --arch="$arch" --dist="$dist" --keyid=$KEYID \
- "$dscfile_basename"
+if [ "$binonly" = 0 ]; then
+ sbuild_args_sourceful="--source"
+fi
-changesfile="${packagenameversion}_${arch}.changes"
+for a in $arch; do
+ echo "I: building $packagenameversion for $a/$dist…" >&2
-mergechanges "$schangesfile" "$changesfile" > temp-combined.changes
-mv temp-combined.changes "$changesfile"
-changestool "$changesfile" updatechecksums
+ case "$a" in
+ all)
+ arch_arg=--arch-all
+ a="$DEB_BUILD_ARCH"
+ ;;
+ *) arch_arg="--arch=$a";;
+ esac
-#sign_changes_file "$changesfile"
+ sbuild $sbuild_args $sbuild_args_sourceful \
+ $arch_arg --dist="$dist" --keyid=$KEYID \
+ "$dscfile_basename" || ret=$?
-dinstall "$dist" "$changesfile"
+ changesfile="${packagenameversion}_${a}.changes"
-DATESTR="$(date +%Y.%m.%d.%H%M%S)"
-BUILD_PREFIX="${packagenameversion}_${arch}.${DATESTR}"
+ if [ -n "$sbuild_args_sourceful" ]; then
+ schangesfile="${packagenameversion}_source+${changesfile#${packagenameversion}_}"
+ mv "$changesfile" "$schangesfile"
+ changesfile="$schangesfile"
+ fi
-mv current "${BUILD_PREFIX}".buildlog
-rm -f current-*
+ # subsequent iterations should be binonly
+ sbuild_args_sourceful=
-bundle="${BUNDLE_DIR}/${BUILD_PREFIX}".bundle.tar
-tar -chf "$bundle" *
-chmod 644 "$bundle"
+ echo "I: running post-build hook ($packagenameversion/$a/$dist)…" >&2
+ postbuild "$dist" "$a" "$changesfile"
+ echo "I: running dinstall ($packagenameversion/$a/$dist)…" >&2
+ dinstall "$dist" "$changesfile"
-rm -r "$BUILDDIR"
-trap - 0
+ echo "I: done building $packagenameversion for $a/$dist" >&2
+done
+
+if [ -n "${schangesfile:-}" ]; then
+ sarch="${schangesfile##*_}"; sarch=${sarch%.changes}
+ other_archs="$(for i in *.changes; do
+ [ "$i" = "$schangesfile" ] && continue
+ t="${i##*_}"; echo "${t%.changes}"
+ done)"
+
+ if [ -n "$other_archs" ]; then
+ combined_arch="${sarch}+${other_archs}"
+ mergechanges *.changes > ${packagenameversion}_${combined_arch}.changes
+ arch="$combined_arch"
+ else
+ arch="$sarch"
+ fi
+fi
+bundle="${BUNDLE_DIR}/${packagenameversion}_${arch}_bundle.tar.gz"
+tar -chzf "$bundle" *
+chmod 644 "$bundle"
print_bundle_location "$bundle"
+cleanup
+
exit 0