X-Git-Url: https://git.madduck.net/code/mbuild.git/blobdiff_plain/48b5848b78e049fb9ac4d9f28c0fc95bfdd9da87..8af604d4c05c04f4024c2c1d4910d755e06c1cff:/mbuild.sh diff --git a/mbuild.sh b/mbuild.sh deleted file mode 100755 index b96f426..0000000 --- a/mbuild.sh +++ /dev/null @@ -1,136 +0,0 @@ -#!/bin/sh -# -# mbuild - automate builds with sbuild and dinstall the result -# -# Copyright (c) 2008 martin f. krafft -# Released under the terms of the Artistic Licence 2.0. -# -set -eu - -ME="${0##*/}" - -BUILDDIR="$(mktemp -dt $ME.XXXXXXXX)" -trap "cd / && rm -R '$BUILDDIR'" 0 - -BUNDLE_DIR="${TMPDIR:-/tmp}" -TARGET_DIR="$PWD" -dinstall() { - echo "Copying files destined for $1 back to $TARGET_DIR..." - dcmd cp -v "$2" "$TARGET_DIR" -} - -KEYID= - -MBUILDRCS="/etc/mbuild/rc $HOME/.mbuildrc $HOME/.mbuild/rc" -for rc in $MBUILDRCS; do - [ -r "$rc" ] && . "$rc" -done - -if [ -z "$KEYID" ]; then - echo "E: \$KEYID is not defined in rc file." >&2 - exit 1 -fi - -DEB_BUILD_ARCH="$(dpkg-architecture -qDEB_BUILD_ARCH)" - -about() -{ - echo "$ME -- wrapper for sbuild" - echo "Copyright © martin f. krafft " - echo "Released under the terms of the Artistic Licence 2.0" -} - -usage() -{ - about - echo - echo "Usage: $ME [options] [sbuild_options] file_source.changes" - echo - echo "Valid options are:" - cat <<-_eof | column -s\& -t - --dist & specify the target distribution (default: sid) - --arch & specify the target architecture (default: $DEB_BUILD_ARCH) - -h|--help & show this output. - -V|--version & show version information. - _eof -} - -sbuild_args= -schangesfile= -arch= -dist= -for opt in "$@"; do - case "$opt" in - -h|--help) usage; exit 0;; - -V|--version) about; exit 0;; - --arch=*) arch="${opt#--arch=}";; - --dist=*) dist="${opt#--dist=}";; - -sa) sbuild_args="${sbuild_args:+$sbuild_args }--force-orig-source";; - --*) sbuild_args="${sbuild_args:+$sbuild_args }$opt";; - *_source.changes) - if [ -z "$schangesfile" ]; then - if [ -f "$opt" ] && [ -r "$opt" ]; then - schangesfile="$opt" - else - echo "E: file does not exist: $opt" >&2 - exit 1 - fi - else - echo "E: cannot pass more than one source changes file: $opt" >&2 - exit 1 - fi - ;; - *) - echo "E: unknown option: $opt" >&1 - exit 1 - ;; - esac -done - -if [ -z "$schangesfile" ]; then - usage - exit 1 -fi - -[ -z "$arch" ] && arch="$DEB_BUILD_ARCH" -[ -z "$dist" ] && dist="unstable" - -schangesfile_basename="${schangesfile##*/}" -packagenameversion="${schangesfile_basename%_*}" - -case "$schangesfile" in - */*) cd "${schangesfile%/*}";; - *) :;; -esac -dcmd cp "${schangesfile##*/}" "$BUILDDIR" -schangesfile="$schangesfile_basename" - -cd "$BUILDDIR" - -sbuild $sbuild_args --arch="$arch" --arch-all --dist="$dist" --keyid=$KEYID \ - "$packagenameversion".dsc - -changesfile="${packagenameversion}_${arch}.changes" - -dinstall "$dist" "$schangesfile" -dinstall "$dist" "$changesfile" - -mv "$changesfile" "${changesfile}.binonly" -mergechanges "$schangesfile" "${changesfile}.binonly" > "$changesfile" -rm "${changesfile}.binonly" "$schangesfile" - -DATESTR="$(date +%Y.%m.%d.%H%M%S)" -BUILD_PREFIX="${packagenameversion}_${arch}.${DATESTR}" - -mv current "${BUILD_PREFIX}".buildlog -rm -f current-* - -bundle="${BUNDLE_DIR}/${BUILD_PREFIX}".bundle.tar -tar -chf "$bundle" * - -rm -r "$BUILDDIR" -trap - 0 - -echo "Bundle available at $bundle ." - -exit 0