X-Git-Url: https://git.madduck.net/code/mbuild.git/blobdiff_plain/6f9b0176686f6d54ce1c5993114648b78c7b10d9..d3c87d0175c44902f7be928745a3dadc80c07632:/sbuild-wrapper.sh diff --git a/sbuild-wrapper.sh b/sbuild-wrapper.sh index 4f6224d..be75ff3 100755 --- a/sbuild-wrapper.sh +++ b/sbuild-wrapper.sh @@ -28,6 +28,9 @@ dinstall() { print_bundle_location() { echo "Bundle available at $@ ." } +postbuild() { + : +} KEYID= @@ -69,6 +72,7 @@ usage() binonly=0 sbuild_args= +sbuild_args_sourceful= schangesfile= arch= for opt in "$@"; do @@ -150,33 +154,66 @@ dcmd "$dscfile_basename" | while read f; do esac done -[ "$binonly" = 0 ] && sbuild_args="${sbuild_args:+$sbuild_args }--source --arch-all" +rm $schangesfile +unset schangesfile + +if [ "$binonly" = 0 ]; then + sbuild_args_sourceful="--source --arch-all" +fi + +if [ "$arch" = all ]; then + arch="$(schroot -l | sed -rne 's,^sid-([^-]+).*,\1,p' | uniq | tr '\n' ' ')" +fi + +for a in $arch; do + echo "I: building $packagenameversion for $a/$dist…" >&2 -sbuild $sbuild_args --arch="$arch" --dist="$dist" --keyid=$KEYID \ - "$dscfile_basename" + sbuild $sbuild_args $sbuild_args_sourceful \ + --arch="$a" --dist="$dist" --keyid=$KEYID \ + "$dscfile_basename" -changesfile="${packagenameversion}_${arch}.changes" + changesfile="${packagenameversion}_${a}.changes" -#mergechanges "$schangesfile" "$changesfile" > temp-combined.changes -#mv temp-combined.changes "$changesfile" -#changestool "$changesfile" updatechecksums + if [ -n "$sbuild_args_sourceful" ]; then + schangesfile="${packagenameversion}_source+${changesfile#${packagenameversion}_}" + mv "$changesfile" "$schangesfile" + changesfile="$schangesfile" + fi -#sign_changes_file "$changesfile" + # subsequent iterations should be binonly + sbuild_args_sourceful= -dinstall "$dist" "$changesfile" + 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" + + echo "I: done building $packagenameversion for $a/$dist" >&2 +done + +if [ -n "${schangesfile:-}" ]; then + sarch="${schangesfile##*_}"; sarch=${sarch%.changes} + combined_arch="$(echo -n "${sarch}+"; + for i in *.changes; do + [ "$i" = "$schangesfile" ] && continue + t="${i##*_}"; echo "${t%.changes}" + done)" + + if [ -n "$combined_arch" ]; then + mergechanges *.changes > ${packagenameversion}_${combined_arch}.changes + arch="$combined_arch" + fi +fi 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" * chmod 644 "$bundle" +print_bundle_location "$bundle" -cleanup -print_bundle_location "$bundle" +cleanup exit 0