blob: 6db3afe90a87b77995a90d9cf311b73cb29698f1 [file] [log] [blame] [view] [edit]
# Build Scripts
Sometimes a normal build from `cargo` is not enough. Perhaps your crate needs
some pre-requisites before `cargo` will successfully compile, things like code
generation, or some native code that needs to be compiled. To solve this problem
we have build scripts that Cargo can run.
To add a build script to your package it can either be specified in the
`Cargo.toml` as follows:
```toml
[package]
...
build = "build.rs"
```
Otherwise Cargo will look for a `build.rs` file in the project directory by
default.
## How to use a build script
The build script is simply another Rust file that will be compiled and invoked
prior to compiling anything else in the package. Hence it can be used to fulfill
pre-requisites of your crate.
Cargo provides the script with inputs via environment variables [specified
here] that can be used.
The script provides output via stdout. All lines printed are written to
`target/debug/build/<pkg>/output`. Further, lines prefixed with `cargo:` will be
interpreted by Cargo directly and hence can be used to define parameters for the
package's compilation.
For further specification and examples have a read of the
[Cargo specification][cargo_specification].
[specified here]: https://doc.rust-lang.org/cargo/reference/environment-variables.html#environment-variables-cargo-sets-for-build-scripts
[cargo_specification]: https://doc.rust-lang.org/cargo/reference/build-scripts.html