]> git.proxmox.com Git - debcargo-conf.git/blame - vars.sh.frag
debcargo: update to 2.6.0
[debcargo-conf.git] / vars.sh.frag
CommitLineData
9cfc4370 1# -*- mode: sh -*-
5e18ef4f
XL
2# Common shell utilities.
3#
4# Envvars:
5# DEBCARGO
6# Path to debcargo. Set this to use your custom version, e.g. from git.
931eabc0
XL
7set -e
8
999f9269 9abort() { local x=$1; shift; for i in "$@"; do echo >&2 "$0: abort: $i"; done; exit "$x"; }
88f8e3e6 10
cfc28aec 11mkdir -p "$(dirname "$0")/.git/hooks"
b6a1d240
XL
12HOOK_COMMIT="$(dirname "$0")/.git/hooks/pre-commit"
13if [ ! -x "$HOOK_COMMIT" ]; then
14cat <<'eof' >"$HOOK_COMMIT"
15#!/bin/sh
16if git rev-parse -q --verify MERGE_HEAD; then exit; fi
17case $(git rev-parse --abbrev-ref HEAD) in
18pending-*) true;;
19*) if git diff --cached --name-only | \
20 grep '^src/.*/debian/changelog$' | \
f830d4fb 21 while read x; do if ! [ -f "$x" ]; then continue; fi; echo "$x: $(head -n1 $x)"; done | \
b6a1d240
XL
22 grep -v UNRELEASED-FIXME-AUTOGENERATED-DEBCARGO; then
23 echo >&2 "please don't finalise changelogs directly on the master branch, use ./release.sh instead"; exit 1;
24 fi;;
25esac
26eof
27chmod +x "$HOOK_COMMIT"
28fi
29
23db3623
XL
30if [ -n "$DEBCARGO" ]; then
31 true
f498b1c4
IJ
32elif type -p debcargo >/dev/null 2>&1; then
33 DEBCARGO=$(type -p debcargo)
23db3623
XL
34elif [ -f "$HOME/.cargo/bin/debcargo" ]; then
35 DEBCARGO="$HOME/.cargo/bin/debcargo"
36else
37 abort 1 "debcargo not found, run \`cargo install debcargo\` or set DEBCARGO to point to it"
38fi
39
40test -x "$DEBCARGO" || abort 1 "debcargo found but not executable: $DEBCARGO"
34c68b28
XL
41dcver=$($DEBCARGO --version | sed -ne 's/debcargo //p')
42case $dcver in
86d55e85 432.0.*|2.1.*|2.2.*|2.3.*) abort 1 "unsupported debcargo version $dcver. try reinstalling with \`cargo install debcargo --force\`";;
5f4657b0 442.4.*) true;;
02f99983 452.5.*) true;;
34c68b28
XL
46*) abort 1 "unsupported debcargo version: $dcver";;
47esac
23db3623 48
32fc064c
XL
49if [ $# -ne 1 -a $# -ne 2 ]; then
50 echo >&2 "Usage: $0 <rust-crate-name>"
51 echo >&2 " $0 <rust-crate-name> <old-version>"
52 echo >&2 "See README.rst for more details on usage."
53 exit 2
54fi
55
999f9269 56CRATE="$1"
ea9f59b2 57VER="$2"
931eabc0 58
609d97bd 59if [ -n "$CRATE" -a -z "$VER" ] && grep -q crate_src_path "src/$CRATE/debian/debcargo.toml" 2>/dev/null; then
5c6aa340
XL
60 # special hack for crate_src_path, could be cleaner...
61 PKGNAME="$CRATE"
62 PKGBASE="$CRATE"
63else
64 PKGNAME=${PKGNAME:-$($DEBCARGO deb-src-name "$CRATE" $VER || abort 1 "couldn't find crate $CRATE")}
65 PKGBASE=${PKGBASE:-$($DEBCARGO deb-src-name "$CRATE" || abort 1 "couldn't find crate $CRATE")}
66fi
67
931eabc0
XL
68PKGDIR_REL="src/$PKGNAME"
69PKGDIR="$PWD/$PKGDIR_REL"
70BUILDDIR="$PWD/build/$PKGNAME"
71PKGCFG="$PKGDIR/debian/debcargo.toml"
1230b71f
XL
72
73mkdir -p "$(dirname $BUILDDIR)"
9cc53ba7 74ln -srf "$PWD/build.sh" "$PWD/build/build.sh"
1057693c 75chmod +x "$PWD/build/build.sh"
1230b71f 76
999f9269
XL
77if [ -z "$CRATE" ]; then
78 abort 2 "Usage: $0 <crate> [<version>]"
1230b71f 79fi
cc003c95
XL
80
81run_debcargo() {
f3600938 82 rm -rf "$BUILDDIR" "$(dirname "$BUILDDIR")/rust-${PKGNAME}_${REALVER:-$VER}"*.orig.tar.*
ba393157 83 $DEBCARGO package --config "$PKGCFG" --directory "$BUILDDIR" "$@" "$CRATE" "${REALVER:-$VER}"
cc003c95 84}
b4e5b9dc
XL
85
86shouldbuild() {
87 local dst="$1"
88 local src="$2"
89 test ! -e "$dst" -o "$src" -nt "$dst"
90}
baae6f7c
XL
91
92get_existing_version() {
93 sed -nre "s/.*Package .* (.*) from crates.io.*/\1/gp" "$1/debian/changelog" | head -n1
94}