X-Git-Url: https://git.madduck.net/code/mbuild.git/blobdiff_plain/e385a3007e11a74cf3ca1e5b998cb8bdfc090dd3..c574dadaa5a6754979188bbed83eb734c6c62d49:/mbuild.sh diff --git a/mbuild.sh b/mbuild.sh index 97fcc53..99ffb2a 100755 --- a/mbuild.sh +++ b/mbuild.sh @@ -1,22 +1,34 @@ #!/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}" +dinstall() { + echo "Would install into $1:" + for file in $(dcmd echo "$2"); do + echo " $file" + done +} -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,31 +63,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" -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