meta: release.sh
cargo-release doesn't do everything we want during the release process, so a separate script ends up being necessary if I don't want to forget steps.pull/48/head
parent
a87d56cfc9
commit
0a0ce0793d
|
@ -1,15 +0,0 @@
|
|||
#!/usr/bin/env bash
|
||||
set -ex
|
||||
|
||||
if ! command -v help2man &> /dev/null
|
||||
then
|
||||
echo "help2man binary could not be found"
|
||||
exit
|
||||
fi
|
||||
|
||||
cargo build
|
||||
|
||||
for binary in "innernet" "innernet-server"; do
|
||||
help2man --no-discard-stderr -s8 "target/debug/$binary" -N > "doc/$binary.8"
|
||||
gzip -f "doc/$binary.8"
|
||||
done
|
|
@ -0,0 +1,37 @@
|
|||
#!/usr/bin/env bash
|
||||
set -e
|
||||
|
||||
die () {
|
||||
echo >&2 "$@"
|
||||
exit 1
|
||||
}
|
||||
|
||||
for command in help2man cargo-release; do
|
||||
if ! command -v $command &> /dev/null
|
||||
then
|
||||
echo "$command binary could not be found"
|
||||
exit
|
||||
fi
|
||||
done
|
||||
|
||||
[ "$#" -eq 1 ] || die "usage: ./release.sh [patch|major|minor|rc]"
|
||||
git diff --quiet || die 'ERROR: git repo is dirty.'
|
||||
|
||||
cargo build
|
||||
|
||||
for binary in "innernet" "innernet-server"; do
|
||||
help2man --no-discard-stderr -s8 "target/debug/$binary" -N > "doc/$binary.8"
|
||||
gzip -f "doc/$binary.8"
|
||||
done
|
||||
|
||||
git add doc
|
||||
git commit -m "meta: update manpages"
|
||||
cargo release "$1" --no-confirm --exclude "hostsfile"
|
||||
|
||||
# re-stage the manpage commit and the cargo-release commit
|
||||
git reset --soft @~2
|
||||
|
||||
VERSION="$(cargo pkgid -p shared | cut -d '#' -f 2)"
|
||||
|
||||
git commit -m "meta: release v$VERSION"
|
||||
git tag "v$VERSION"
|
Loading…
Reference in New Issue