Add install script and installation section to readme

type: distribution
This commit is contained in:
Casey Rodarmor 2020-01-31 02:58:58 -08:00
parent 9dd8a56298
commit e2cf93efb0
No known key found for this signature in database
GPG Key ID: 556186B153EC6FE0
3 changed files with 157 additions and 1 deletions

View File

@ -3,6 +3,10 @@
## Manual ## Manual
- [General](#general) - [General](#general)
- [Installation](#installation)
- [Supported Operating Systems](#supported-operating-systems)
- [Pre-built binaries](#pre-built-binaries)
- [Cargo](#cargo)
- [Semantic Versioning](#semantic-versioning) - [Semantic Versioning](#semantic-versioning)
- [Unstable Features](#unstable-features) - [Unstable Features](#unstable-features)
- [Bittorrent](#bittorrent) - [Bittorrent](#bittorrent)
@ -12,6 +16,35 @@
## General ## General
### Installation
#### Supported Operating Systems
`imdl` supports both unix and Windows. It is tested on Linux, MacOS, and
Windows, but should work on other unix OSs. If it does not, please open an
issue!
#### Pre-built binaries
Pre-built binaries for Linux, macOS, and Windows can be found on
[the releases page](https://github.com/casey/intermodal/releases).
You can use the following command to download the latest binary for Linux,
MacOS or Windows, just replace `DEST` with the directory where you'd like to
install the `imdl` binary:
```sh
curl --proto '=https' --tlsv1.2 -sSf \
https://raw.githubusercontent.com/casey/intermodal/master/bin/install \
| bash -s -- --to DEST
```
#### Cargo
`imdl` is written in [Rust](https://www.rust-lang.org/) and can be built from
source and installed with `cargo install imdl`. To get Rust, use the
[rustup installer](https://rustup.rs/).
### Semantic Versioning ### Semantic Versioning
Intermodal follows [semantic versioning](https://semver.org/). Intermodal follows [semantic versioning](https://semver.org/).

123
bin/install Executable file
View File

@ -0,0 +1,123 @@
#!/usr/bin/env bash
set -eu
help() {
cat <<'EOF'
Install a binary release of a imdl hosted on GitHub
Usage:
install [options]
Options:
-h, --help Display this message
-f, --force Force overwriting an existing binary
--tag TAG Tag (version) of the crate to install (default <latest release>)
--to LOCATION Where to install the binary (default ~/.cargo/bin)
EOF
}
git=casey/intermodal
crate=imdl
url=https://github.com/casey/intermodal
releases=$url/releases
case `uname -s` in
Darwin) target=x86_64-apple-darwin;;
Linux) target=x86_64-unknown-linux-musl;;
*) target=x86_64-pc-windows-msvc;;
esac
say() {
echo "install: $1"
}
say_err() {
say "$1" >&2
}
err() {
if [ ! -z ${td-} ]; then
rm -rf $td
fi
say_err "ERROR $1"
exit 1
}
need() {
if ! command -v $1 > /dev/null 2>&1; then
err "need $1 (command not found)"
fi
}
force=false
while test $# -gt 0; do
case $1 in
--force | -f)
force=true
;;
--help | -h)
help
exit 0
;;
--tag)
tag=$2
shift
;;
--to)
dest=$2
shift
;;
*)
;;
esac
shift
done
# Dependencies
need basename
need curl
need install
need mkdir
need mktemp
need tar
# Optional dependencies
if [ -z ${tag-} ]; then
need cut
need rev
fi
if [ -z ${dest-} ]; then
dest="$HOME/.cargo/bin"
fi
if [ -z ${tag-} ]; then
tag=$(curl -s "$releases/latest" | cut -d'"' -f2 | rev | cut -d'/' -f1 | rev)
fi
archive="$releases/download/$tag/$crate-$tag-$target.tar.gz"
say_err "Repository: $url"
say_err "Crate: $crate"
say_err "Tag: $tag"
say_err "Target: $target"
say_err "Destination: $dest"
say_err "Archive: $archive"
td=$(mktemp -d || mktemp -d -t tmp)
curl -sL $archive | tar -C $td -xz
for f in $(ls $td); do
test -x $td/$f || continue
if [ -e "$dest/$f" ] && [ $force = false ]; then
err "$f already exists in $dest"
else
mkdir -p $dest
install -m 755 $td/$f $dest
fi
done
rm -rf $td

View File

@ -31,7 +31,7 @@ impl Opt {
let text = captures.name("TEXT").unwrap().as_str(); let text = captures.name("TEXT").unwrap().as_str();
let level = marker.len(); let level = marker.len();
let indentation = " ".repeat((level - 2) * 2); let indentation = " ".repeat((level - 2) * 2);
let slug = text.to_lowercase().replace(' ', "-"); let slug = text.to_lowercase().replace(' ', "-").replace('.', "");
toc.push(format!("{}- [{}](#{})", indentation, text, slug)); toc.push(format!("{}- [{}](#{})", indentation, text, slug));
} }