repo/extra/cbindgen/build

62 lines
1.7 KiB
Plaintext
Raw Normal View History

2019-08-03 00:40:30 +00:00
#!/bin/sh -e
2020-03-12 14:57:09 +00:00
#
# Seeing as this is the only rust package in the
# repositories (other than rust itself), this will
# also serve as a reference to writing network-free
# rust-based packages.
2019-08-03 00:40:30 +00:00
2020-03-12 14:57:09 +00:00
# Set the CARGO_HOME variable to the current directory
# to prevent cargo from touching '$HOME/.cargo'. This
# keeps the build contained to the package manager's
# domain.
export CARGO_HOME=$PWD
2019-10-08 08:22:32 +00:00
2020-03-12 14:57:09 +00:00
# Extract each crate and generate a checksum file.
# This effectively mimics 'cargo vendor' without the
# network requirement.
#
# This allows the package manager to cache each crate
# and handle them as regular sources.
(
cd vendor
# Download link for this crate 404s. Mirror link saves
# the file as 'download' so it must be renamed.
mv -f download wasi-0.9.0+wasi-snapshot-preview1.crate
2020-03-12 14:57:09 +00:00
for crate in *.crate; do
tar xf "$crate"
# Strip the filename from the sha256sum output.
sha256=$(sha256sum "$crate")
sha256=${sha256%% *}
printf '{"package":"%s","files":{}}\n' "$sha256" \
> "${crate%.crate}/.cargo-checksum.json"
done
)
# Cargo reads a "global" configuration file from $CARGO_HOME,
# as we've set it to $PWD this is where we'll be storing the
# vendor config.
mkdir -p .cargo
# Create the configuration file to tell cargo to look in the
# 'vendor' directory for the already downloaded sources
# rather than crates.io (over network).
cat <<EOF > .cargo/config
[source.crates-io]
replace-with = "vendored-sources"
[source.vendored-sources]
directory = "vendor"
EOF
# Use the '--frozen' flag to tell cargo to skip the network
# and use whatever dependencies are in the Cargo.[toml|lock]
# files.
2021-07-05 21:38:59 +00:00
cargo build --release --frozen
2019-10-08 08:22:32 +00:00
2021-07-01 16:26:38 +00:00
mkdir -p "$1/usr/bin"
cp -f target/release/cbindgen "$1/usr/bin"