2020-09-19 03:50:27 +02:00
< h1 align = "center" > Intermodal< / h1 >
2020-01-16 08:37:12 +01:00
2020-09-19 03:50:27 +02:00
< div align = "center" > A 40' shipping container for the Internet< / div >
< br / >
< div align = "center" >
< a href = "https://crates.io/crates/imdl" > < img src = "https://img.shields.io/crates/v/imdl.svg?logo=rust" alt = "crate" / > < / a >
< a href = "https://github.com/casey/intermodal/actions" > < img src = "https://github.com/casey/intermodal/workflows/Build/badge.svg" alt = "build" / > < / a >
< a href = "https://imdl.io/book/" > < img src = "https://img.shields.io/static/v1?logo=read-the-docs&label=book&message=imdl.io&color=informational" alt = "book" / > < / a >
< a href = "https://discord.gg/HaaT5Qz" > < img src = "https://img.shields.io/discord/679283456261226516.svg?logo=discord&color=7289da" alt = "chat" / > < / a >
< / div >
< br / >
2020-02-18 11:53:23 +01:00
2020-04-18 07:49:56 +02:00
Intermodal is a user-friendly and featureful command-line BitTorrent metainfo
utility. The binary is called `imdl` and runs on Linux, Windows, and macOS.
2020-03-27 22:19:21 +01:00
2020-04-18 07:49:56 +02:00
At the moment, creation, viewing, and verification of `.torrent` files is
supported. See [the book ](https://imdl.io/book/ ) for examples and usage
information.
2020-03-27 05:54:54 +01:00
2020-04-18 07:49:56 +02:00
For more about the project and its goals, check out
[this post ](https://rodarmor.com/blog/intermodal ).
2020-03-14 08:32:13 +01:00
2020-03-28 11:56:08 +01:00
![demonstration animation ](https://raw.githubusercontent.com/casey/intermodal/master/www/demo.gif )
2020-04-16 13:16:40 +02:00
## Table of Contents
- [Supported Operating Systems ](#supported-operating-systems )
- [Packages ](#packages )
- [Pre-built binaries ](#pre-built-binaries )
2020-04-20 04:52:10 +02:00
- [Linux and MacOS Install Script ](#linux-and-macos-install-script )
2020-04-16 13:16:40 +02:00
- [Cargo ](#cargo )
2020-04-23 23:34:33 +02:00
- [Shell Completion Scripts ](#shell-completion-scripts )
2020-04-23 04:08:12 +02:00
- [Usage ](#usage )
- [Commands ](#commands )
- [Examples ](#examples )
- [FAQ ](#faq )
2020-04-23 23:34:33 +02:00
- [Notes for Packagers ](#notes-for-packagers )
2020-05-01 06:21:20 +02:00
- [Build Artifacts ](#build-artifacts )
2020-04-23 23:34:33 +02:00
- [Release Updates ](#release-updates )
2020-04-18 07:49:56 +02:00
- [Chat ](#chat )
- [Contributing ](#contributing )
2020-05-26 22:56:42 +02:00
- [Benchmarks ](#benchmarks )
2020-04-16 13:16:40 +02:00
- [Semantic Versioning ](#semantic-versioning )
- [Unstable Features ](#unstable-features )
- [Source Signatures ](#source-signatures )
2020-02-04 16:55:50 +01:00
- [Acknowledgments ](#acknowledgments )
2020-01-21 06:41:39 +01:00
2020-04-16 13:16:40 +02:00
## Installation
2020-01-21 06:41:39 +01:00
2020-04-16 13:16:40 +02:00
### Supported Operating Systems
2020-01-31 11:58:58 +01:00
2020-04-10 05:28:39 +02:00
`imdl` supports Linux, MacOS, and Windows, and should work on other unix OSes.
If it does not, please open an issue!
2020-01-31 11:58:58 +01:00
2020-04-16 13:16:40 +02:00
### Packages
2020-04-12 02:20:45 +02:00
2020-08-28 00:05:12 +02:00
| Operating System | Package Manager | Package | Command |
|:--------------------------------------------------------------------:|:--------------------------------------------------:|:-------------------------------------------------------------------------------------------------:|:-------------------------------------------------------------------------------------:|
| [Various ](https://forge.rust-lang.org/release/platform-support.html ) | [Cargo ](https://www.rust-lang.org ) | [imdl ](https://crates.io/crates/imdl ) | `cargo install imdl` |
| [Arch Linux ](https://www.archlinux.org ) | [Yay ](https://github.com/Jguer/yay ) | [intermodal-bin ](https://aur.archlinux.org/packages/intermodal-bin )< sup > AUR</ sup > | `yay -S intermodal-bin` |
| [Arch Linux ](https://www.archlinux.org ) | [Yay ](https://github.com/Jguer/yay ) | [intermodal ](https://aur.archlinux.org/packages/intermodal )< sup > AUR</ sup > | `yay -S intermodal` |
| [Arch Linux ](https://www.archlinux.org ) | Manual Installation | [intermodal ](https://aur.archlinux.org/packages/intermodal )< sup > AUR</ sup > | [wiki ](https://wiki.archlinux.org/index.php/Arch_User_Repository#Installing_packages ) |
| [Void Linux ](https://voidlinux.org ) | [XBPS ](https://docs.voidlinux.org/xbps/index.html ) | [intermodal ](https://github.com/void-linux/void-packages/blob/master/srcpkgs/intermodal/template ) | `xbps-install -S intermodal` |
2020-04-12 02:20:45 +02:00
2020-04-16 13:16:40 +02:00
### Pre-built binaries
2020-01-31 11:58:58 +01:00
Pre-built binaries for Linux, macOS, and Windows can be found on
[the releases page ](https://github.com/casey/intermodal/releases ).
2020-04-20 04:52:10 +02:00
### Linux and MacOS Install Script
You can use the following command on Linux and MacOS to download the latest
binary, just replace `DEST` with the directory where you'd like to install the
`imdl` binary:
2020-01-31 11:58:58 +01:00
```sh
2020-01-31 13:28:40 +01:00
curl --proto '=https' --tlsv1.2 -sSf https://imdl.io/install.sh | bash -s -- --to DEST
2020-01-31 11:58:58 +01:00
```
2020-04-10 05:28:39 +02:00
A good place to install personal binaries is `~/bin` , which `install.sh` uses
when `--to` is not supplied. To create the `~/bin` directory and install `imdl`
there, do:
```sh
curl --proto '=https' --tlsv1.2 -sSf https://imdl.io/install.sh | bash
```
Additionally, you'll have to add `~/bin` to the `PATH` environment variable,
which the system uses to find executables. How to do this depends on the shell.
For `sh` , `bash` , and `zsh` , it should be done in `~/.profile` :
```sh
echo 'export PATH=$HOME/bin:$PATH' >> ~/.profile
```
For `fish` , it should be done in `~/.config/fish/config.fish` :
```fish
echo 'set -gx PATH ~/bin $PATH' >> ~/.config/fish/config.fish
```
2020-04-16 13:16:40 +02:00
### Cargo
2020-01-31 11:58:58 +01:00
`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/ ).
2020-04-23 23:34:33 +02:00
### Shell Completion Scripts
2020-03-28 06:46:41 +01:00
Shell completion scripts for Bash, Zsh, Fish, PowerShell, and Elvish are
2020-04-21 09:27:07 +02:00
included in all [binary releases ](https://github.com/casey/imdl/releases ).
2020-04-16 13:16:40 +02:00
For Bash, move `imdl.bash` to `$XDG_CONFIG_HOME/bash_completion` or
`/etc/bash_completion.d/` .
For Fish, move `imdl.fish` to `$HOME/.config/fish/completions/` .
For the Z shell, move `_imdl` to one of your `$fpath` directories.
For PowerShell, add `. _imdl.ps1` to your PowerShell
[profile ](https://technet.microsoft.com/en-us/library/bb613488(v=vs.85 ).aspx)
(note the leading period). If the `_imdl.ps1` file is not on your `PATH` , do
`. /path/to/_imdl.ps1` instead.
2020-03-28 06:46:41 +01:00
The `imdl` binary can also generate the same completion scripts at runtime,
using the `completions` command:
```sh
$ imdl completions --shell bash > imdl.bash
```
2020-04-16 13:16:40 +02:00
The `--dir` argument can be used to write a completion script into a directory
with a filename that's appropriate for the shell. For example, the following
command will write the Z shell completion script to `$fpath[0]/_imdl` :
```sh
$ imdl completions --shell zsh --dir $fpath[0]
```
2020-04-23 04:08:12 +02:00
## Usage
Online documentation is available in the book, hosted
[here ](https://imdl.io/book/ ).
### Commands
Adding `--help` to any command will print help text about how to use that
command, including detailed information about any command-line arguments it
accepts.
So, to get information about `imdl torrent create` , run `imdl torrent create
--help`.
Additionally, the same help text is available online in
[the book ](https://imdl.io/book/ ).
### Examples
The intro to [the book ](https://imdl.io/book/ ) has a few simple examples. Check
[the FAQ ](https://imdl.io/book/faq.html ) for more complex usage examples.
### FAQ
The [FAQ ](https://imdl.io/book/faq.html ) covers a variety of specific
use-cases. If there's a use case you think should be covered, feel free to open
[an issue ](https://github.com/casey/intermodal/issues/new ).
2020-04-23 23:34:33 +02:00
## Notes for Packagers
First off, thank you very much! If I can do anything to make packaging
Intermodal easier, please don't hesistate to open
[an issue ](https://github.com/casey/intermodal/issues/new ).
The Intermodal binary is called `imdl` , and the suggested name for the package
is `intermodal` .
Intermodal is written in Rust, and can be built with `cargo build --release` .
Intermodal is distributed under the
[Creative Commons Zero ](https://creativecommons.org/share-your-work/public-domain/cc0/ ),
a public domain dedication with a fallback all-permissive license. The SPDX
identifier of the CC0 is [CC0-1.0 ](https://spdx.org/licenses/CC0-1.0.html ).
2020-05-01 06:21:20 +02:00
### Build Artifacts
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
There are a number of build artifacts: the binary, the man pages, the
changelog, and the shell completion scripts.
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
The binary is built with `cargo` , and the other artifacts are built `gen` ,
located in `bin/gen` .
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
The binary can be built with:
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
cargo build --release
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
_`gen` requires [`help2man` ](https://www.gnu.org/software/help2man/ ) to be
installed, which is used to generate man pages from subcommand `--help`
strings._
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
The rest of the build artifacts can be built with `gen` :
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
cargo run --package gen -- --bin target/release/imdl all
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
_The path to the built `imdl` executable should be passed to `gen` with the `--bin` flag._
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
After running the above commands, the following table shows the location of the
built artifacts.
2020-04-23 23:34:33 +02:00
2020-05-01 06:21:20 +02:00
| Artifact | Location |
|--------------------|----------------------------|
| Binary | `target/release/imdl` |
| Man Pages | `target/gen/man/*` |
| Completion Scripts | `target/gen/completions/*` |
| Changelog | `target/gen/CHANGELOG.md` |
| Readme | `target/gen/README.md` |
2020-04-23 23:34:33 +02:00
### Release Updates
2020-04-24 00:26:50 +02:00
If you'd like to receive an update whenever a new version is released, you can
watch the intermodal repository in "Releases only" mode.
2020-04-23 23:34:33 +02:00
2020-04-18 07:49:56 +02:00
## Chat
2020-06-26 03:47:24 +02:00
The primary chat is on [Discord ](https://discord.gg/HaaT5Qz ).
2020-04-18 07:49:56 +02:00
## Contributing
Your bug reports, feature requests, pull requests, and design help are much
appreciated!
Check out issues with the
["good first issue" label ](https://github.com/casey/intermodal/labels/good%20first%20issue )
for some ideas.
Quite a few files are generated by the program in `bin/gen` . Some files are
generated from templates, so those templates should be edited to make changes
to those files:
- `bin/gen/templates/SUMMARY.md` -> `book/src/SUMMARY.md`
- `bin/gen/templates/README.md` -> `README.md`
- `bin/gen/templates/introduction.md` -> `book/src/introduction.md`
Some files are completely generated, and so shouldn't be manually edited at
all:
- `CHANGELOG.md`
- `book/src/commands/*`
- `completions/*`
- `man/*`
All files can be regenerated by running `cargo run --package gen all` , or
`just gen` , if you have [just ](https://github.com/casey/just ) installed.
The changelog is generated from YAML metadata in commit messages. Here is an
example commit message, with metadata:
```
Upgrade foo
Upgrade foo to v7.5, which is much better.
type: changed
pr:
- https://github.com/casey/intermodal/pull/1
fixes:
- https://github.com/intermodal/issues/2
- https://github.com/intermodal/issues/3
```
The only required field is `type` . To see the possible values for `type` , run
`cargo run --package gen commit-types` .
2020-05-26 22:56:42 +02:00
## Benchmarks
Performance benchmarks can be run with:
```shell
$ cargo bench --features bench
```
The benchmark framework used is [`criterion` ](https://github.com/bheisler/criterion.rs ).
The bench targets themselves are in the `benches` directory. These targets call benchmarking functions in `src/benches.rs` , which are only enabled when the `bench` feature is enabled.
2020-04-16 13:16:40 +02:00
## Semantic Versioning
2020-01-21 06:41:39 +01:00
Intermodal follows [semantic versioning ](https://semver.org/ ).
In particular:
- v0.0.X: Breaking changes may be introduced at any time.
- v0.X.Y: Breaking changes may only be introduced with a minor version number
bump.
- vX.Y.Z: Breaking changes may only be introduced with a major version number
bump
2020-04-16 13:16:40 +02:00
## Unstable Features
2020-01-21 06:41:39 +01:00
To avoid premature stabilization and excessive version churn, unstable features
2020-01-30 10:52:07 +01:00
are unavailable unless the `--unstable` / `-u` flag is passed, for example
`imdl --unstable torrent create .` . Unstable features may be changed or removed
at any time.
2020-01-21 06:41:39 +01:00
2020-04-16 13:16:40 +02:00
## Source Signatures
2020-04-04 10:41:58 +02:00
All commits to the intermodal master branch signed with Casey Rodarmor's PGP
key with fingerprint `3259DAEDB29636B0E2025A70556186B153EC6FE0` , which can be
found
[on keybase ](https://keybase.io/rodarmor/pgp_keys.asc?fingerprint=3259daedb29636b0e2025a70556186b153ec6fe0 ) and on
2020-04-04 11:33:46 +02:00
[his homepage ](https://rodarmor.com/static/rodarmor.asc ).
2020-04-04 10:41:58 +02:00
2020-02-04 16:55:50 +01:00
## Acknowledgments
The formatting of `imdl torrent show` is entirely copied from
[torf ](https://github.com/rndusr/torf-cli ), an excellent command-line torrent
creator, editor, and viewer.