2019-06-12 19:59:50 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# package the build artifacts
|
|
|
|
|
|
|
|
set -ex
|
|
|
|
|
|
|
|
. "$(dirname $0)/utils.sh"
|
|
|
|
|
|
|
|
# Generate artifacts for release
|
|
|
|
mk_artifacts() {
|
|
|
|
CARGO="$(builder)"
|
2019-06-12 20:07:46 +00:00
|
|
|
"$CARGO" build --target "$TARGET" --release
|
2019-06-12 19:59:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
mk_tarball() {
|
|
|
|
# When cross-compiling, use the right `strip` tool on the binary.
|
|
|
|
local gcc_prefix="$(gcc_prefix)"
|
|
|
|
# Create a temporary dir that contains our staging area.
|
|
|
|
# $tmpdir/$name is what eventually ends up as the deployed archive.
|
|
|
|
local tmpdir="$(mktemp -d)"
|
|
|
|
local name="${PROJECT_NAME}-${TRAVIS_TAG}-${TARGET}"
|
|
|
|
local staging="$tmpdir/$name"
|
|
|
|
mkdir -p "$staging"/{complete,doc}
|
|
|
|
# The deployment directory is where the final archive will reside.
|
|
|
|
# This path is known by the .travis.yml configuration.
|
|
|
|
local out_dir="$(pwd)/deployment"
|
|
|
|
mkdir -p "$out_dir"
|
|
|
|
# Find the correct (most recent) Cargo "out" directory. The out directory
|
|
|
|
# contains shell completion files and the man page.
|
|
|
|
local cargo_out_dir="$(cargo_out_dir "target/$TARGET")"
|
|
|
|
|
2019-06-18 16:05:44 +00:00
|
|
|
bin_ext=""
|
|
|
|
if is_windows; then
|
|
|
|
bin_ext=".exe"
|
|
|
|
fi
|
|
|
|
|
2019-06-15 08:20:10 +00:00
|
|
|
# Copy the binaries and strip it.
|
|
|
|
for binary in rga rga-preproc; do
|
2019-06-18 16:05:44 +00:00
|
|
|
cp "target/$TARGET/release/$binary$bin_ext" "$staging/$binary$bin_ext"
|
|
|
|
# "${gcc_prefix}strip" "$staging/$binary"
|
2019-06-15 09:27:27 +00:00
|
|
|
done
|
2019-06-12 19:59:50 +00:00
|
|
|
# Copy the licenses and README.
|
2019-06-14 21:30:31 +00:00
|
|
|
cp {README.md,LICENSE.md} "$staging/"
|
2019-06-12 19:59:50 +00:00
|
|
|
# Copy documentation and man page.
|
2019-06-14 21:30:31 +00:00
|
|
|
# cp {CHANGELOG.md,FAQ.md,GUIDE.md} "$staging/doc/"
|
2019-06-14 21:29:15 +00:00
|
|
|
#if command -V a2x 2>&1 > /dev/null; then
|
|
|
|
# # The man page should only exist if we have asciidoc installed.
|
|
|
|
# cp "$cargo_out_dir/rg.1" "$staging/doc/"
|
|
|
|
#fi
|
2019-06-12 19:59:50 +00:00
|
|
|
# Copy shell completion files.
|
2019-06-14 21:55:56 +00:00
|
|
|
# cp "$cargo_out_dir"/{rg.bash,rg.fish,_rg.ps1} "$staging/complete/"
|
|
|
|
# cp complete/_rg "$staging/complete/"
|
2019-06-12 19:59:50 +00:00
|
|
|
|
2019-06-18 19:39:33 +00:00
|
|
|
if is_windows; then
|
|
|
|
(cd "$tmpdir" && zip -r "$out_dir/$name.zip" "$name")
|
|
|
|
else
|
|
|
|
(cd "$tmpdir" && tar czf "$out_dir/$name.tar.gz" "$name")
|
|
|
|
fi
|
2019-06-12 19:59:50 +00:00
|
|
|
rm -rf "$tmpdir"
|
|
|
|
}
|
|
|
|
|
|
|
|
main() {
|
|
|
|
mk_artifacts
|
|
|
|
mk_tarball
|
|
|
|
}
|
|
|
|
|
|
|
|
main
|