45 lines
1.1 KiB
Markdown
45 lines
1.1 KiB
Markdown
# NIH-plug: bundler and other utilities
|
|
|
|
This is NIH-plug's `cargo xtask` command, as a library. This way you can use it
|
|
in your own projects without having to either fork this repo or vendor the
|
|
binary into your own repo. This is necessary until Cargo supports [running
|
|
binaries from dependencies
|
|
directly](https://github.com/rust-lang/rfcs/pull/3168).
|
|
|
|
To use this, add an `xtask` binary to your project using `cargo new --bin xtask`. Then add that binary to the Cargo workspace in your repository's main
|
|
`Cargo.toml` file like so:
|
|
|
|
```toml
|
|
# Cargo.toml
|
|
|
|
[workspace]
|
|
members = ["xtask"]
|
|
```
|
|
|
|
Add `nih_plug_xtask` to the new xtask package's dependencies, and call its main
|
|
function from the new xtask binary:
|
|
|
|
```toml
|
|
# xtask/Cargo.toml
|
|
|
|
[dependencies]
|
|
nih_plug_xtask = { git = "https://github.com/robbert-vdh/nih-plug.git" }
|
|
```
|
|
|
|
```rust
|
|
// xtask/src/main.rs
|
|
|
|
fn main() -> nih_plug_xtask::Result<()> {
|
|
nih_plug_xtask::main()
|
|
}
|
|
```
|
|
|
|
Lastly, create a `.cargo/config` file in your repository and add a Cargo alias.
|
|
This allows you to run the binary using `cargo xtask`:
|
|
|
|
```toml
|
|
# .cargo/config
|
|
|
|
[alias]
|
|
xtask = "run --package xtask --release --"
|
|
```
|