From: martin f. krafft Date: Fri, 25 Apr 2008 17:36:29 +0000 (+0400) Subject: factor out reprepro stuff to config file X-Git-Url: https://git.madduck.net/code/mbuild.git/commitdiff_plain/1fb9ec9cc15fd2c74048317ba38f57c6aaf2c72c?ds=inline factor out reprepro stuff to config file --- diff --git a/mbuild.sh b/mbuild.sh index 97fcc53..b4face4 100755 --- a/mbuild.sh +++ b/mbuild.sh @@ -1,24 +1,38 @@ #!/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="$BUILDDIR" +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 + +cd "$BUILDDIR" -sbuild_args= +sbuild_args=--debug schangesfile= arch= dist= @@ -51,31 +65,30 @@ done schangesfile_basename="${schangesfile##*/}" packagenameversion="${schangesfile_basename%_*}" -builddir="$(mktemp -dp "$DIR" "${packagenameversion}.XXXXXXXX")" -trap "rm -R '$builddir'" 0 - cd "${schangesfile%/*}" -dcmd cp "${schangesfile##*/}" "$builddir" +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" +dcmd tar -cvhf "$bundle" "$changesfile" -rm -r "$builddir" +rm -r "$BUILDDIR" trap - 0 -echo "Bundle available at $bundle" +echo "Bundle available at $bundle ." + +exit 0