X-Git-Url: https://git.madduck.net/code/mbuild.git/blobdiff_plain/74486b127a521eb20a034bb22210005ca67dabd2..37f7b113fb46cc8121b5d8a2a81655d8e68c120f:/mbuild.sh diff --git a/mbuild.sh b/mbuild.sh index 2b4f5b4..1ea10b6 100755 --- a/mbuild.sh +++ b/mbuild.sh @@ -1,22 +1,33 @@ #!/bin/sh # -# mbuild - make sbuild and reprepro work together +# 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 -BUNDLEDIR="$HOME/reprepro/bundles" -REPREPRODIR="$HOME/reprepro" +BUILDDIR="$(mktemp -dt mbuild.XXXXXXXX)" +trap "cd / && rm -R '$BUILDDIR'" 0 -DINSTALL="reprepro --basedir $REPREPRODIR include \$dist" +BUNDLE_DIR="${TMPDIR:-/tmp}" +TARGET_DIR="$PWD" +dinstall() { + echo "Copying files destined for $1 back to $TARGET_DIR..." + dcmd cp -v "$2" "$TARGET_DIR" +} -GNUPGHOME="$REPREPRODIR/.gnupg"; export GNUPGHOME -KEYID=330c4a75 +KEYID= -DIR="$HOME/sbuild" -cd "$DIR" +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 sbuild_args= schangesfile= @@ -51,33 +62,39 @@ done schangesfile_basename="${schangesfile##*/}" packagenameversion="${schangesfile_basename%_*}" -builddir="$(mktemp -dp "$DIR" "${packagenameversion}.XXXXXXXX")" -trap "rm -R '$builddir'" 0 - -cd "${schangesfile%/*}" -dcmd cp "${schangesfile##*/}" "$builddir" +case "$schangesfile" in + */*) cd "${schangesfile%/*}";; + *) :;; +esac +dcmd cp "${schangesfile##*/}" "$BUILDDIR" schangesfile="$schangesfile_basename" -cd "$builddir" +cd "$BUILDDIR" sbuild $sbuild_args --arch="$arch" --arch-all --dist="$dist" --keyid=$KEYID \ "$packagenameversion".dsc changesfile="${packagenameversion}_${arch}.changes" -$SHELL - -eval $DINSTALL "$schangesfile" -eval $DINSTALL "$changesfile" +dinstall "$dist" "$schangesfile" +dinstall "$dist" "$changesfile" mv "$changesfile" "${changesfile}.binonly" mergechanges "$schangesfile" "${changesfile}.binonly" > "$changesfile" rm "${changesfile}.binonly" "$schangesfile" -bundle="$BUNDLEDIR/${packagenameversion}.bundle.tar" -dcmd tar -chf "$bundle" "$changesfile" +DATESTR="$(date +%Y.%m.%d.%H%M%S)" +BUILD_PREFIX="${packagenameversion}_${arch}.${DATESTR}" -rm -r "$builddir" +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" +echo "Bundle available at $bundle ." + +exit 0