# vergen
### `vergen`, `vergen-git2`, `vergen-gitcl`, `vergen-gix`, `vergen-pretty`
The `vergen` suite of tools allow you to embed environment variables generated at build time into your code. For example,
I may care about the last git commit number and need to reference it in my code. You can configure one of the `vergen` git tools in cargo [build scripts](https://doc.rust-lang.org/cargo/reference/build-scripts.html) and can emit a `VERGEN_GIT_SHA` environment variable for use in your code.
The `vergen` suite of tools can emit the following [output]((https://doc.rust-lang.org/cargo/reference/build-scripts.html#outputs-of-the-build-script)):
- Will emit [`cargo:rustc-env=VAR=VALUE`](https://doc.rust-lang.org/cargo/reference/build-scripts.html#cargorustc-envvarvalue)
for each feature you have enabled. These can be referenced with the [`env!`](https://doc.rust-lang.org/std/macro.env.html) or [`option_env!`](https://doc.rust-lang.org/std/macro.option_env.html) macro in your code.
- If using one of the git enabled libraries, will emit [`cargo:rerun-if-changed=.git/HEAD`](https://doc.rust-lang.org/cargo/reference/build-scripts.html#rerun-if-changed). This is done to ensure any git instructions are regenerated when commits are made.
- If using one of the git enabled libraries, will emit [`cargo:rerun-if-changed=.git/<path_to_ref>`](https://doc.rust-lang.org/cargo/reference/build-scripts.html#rerun-if-changed). This is done to ensure any git instructions are regenerated when commits are made.
- Can emit [`cargo:warning`](https://doc.rust-lang.org/cargo/reference/build-scripts.html#cargo-warning) outputs if the
[`fail_on_error`](EmitBuilder::fail_on_error) feature is not enabled and the requested variable is defaulted through error or
the [`idempotent`](EmitBuilder::idempotent) flag.
- Will emit [`cargo:rerun-if-changed=build.rs`](https://doc.rust-lang.org/cargo/reference/build-scripts.html#rerun-if-changed)
to rerun instruction emission if the `build.rs` file changed.
- Will emit [`cargo:rerun-if-env-changed=VERGEN_IDEMPOTENT`](https://doc.rust-lang.org/cargo/reference/build-scripts.html#rerun-if-changed)
to rerun instruction emission if the `VERGEN_IDEMPOTENT` environment variable has changed.
- Will emit [`cargo:rerun-if-env-changed=SOURCE_DATE_EPOCH`](https://doc.rust-lang.org/cargo/reference/build-scripts.html#rerun-if-changed)
to rerun instruction emission if the `SOURCE_DATE_EPOCH` environment variable has changed.
`vergen-pretty` is a macro and pretty printer for `vergen` based cargo instruction output.
## Current Releases
### vergen
[data:image/s3,"s3://crabby-images/bab1b/bab1ba0767b27c35dfdff7882938e547d82249b4" alt="docs.rs"](https://docs.rs/vergen)
[data:image/s3,"s3://crabby-images/b8468/b8468099b951bd54885bf7dcb7a878491c762f94" alt="Crates.io"](https://crates.io/crates/vergen)
[data:image/s3,"s3://crabby-images/dc8ab/dc8abb0b23d507f8ad1371b45d47a860f8bffe26" alt="Crates.io"](https://crates.io/crates/vergen)
[data:image/s3,"s3://crabby-images/d7128/d71285efc7a5ad55ca77cbaf6dd7fb80b2716754" alt="Crates.io"](https://crates.io/crates/vergen)
[data:image/s3,"s3://crabby-images/5796d/5796d0d692d75edea69d34e96245b796664612ed" alt="codecov"](https://codecov.io/gh/rustyhorde/vergen)
[data:image/s3,"s3://crabby-images/96ff5/96ff5b686d2bd7a224b5e5982d0b6209901b510c" alt="CI"](https://github.com/rustyhorde/vergen/actions)
[data:image/s3,"s3://crabby-images/91761/917617a8e6b700063af4efae9f86795ae7407db6" alt="sponsor"](https://github.com/sponsors/CraZySacX)
### vergen-git2
[data:image/s3,"s3://crabby-images/df901/df901cb7697b965301e654f69cb0e1f24efd0898" alt="docs.rs"](https://docs.rs/vergen-git2)
[data:image/s3,"s3://crabby-images/7e581/7e581029376c1a9772bf27770a80a84fa421048d" alt="Crates.io"](https://crates.io/crates/vergen-git2)
[data:image/s3,"s3://crabby-images/f5b60/f5b6073afb09a02297ad32a6ac888a8a80851ab6" alt="Crates.io"](https://crates.io/crates/vergen-git2)
[data:image/s3,"s3://crabby-images/ac011/ac0112bf3ac637c6a1528bb3cb87efbd9ec10bd6" alt="Crates.io"](https://crates.io/crates/vergen-git2)
### vergen-gitcl
[data:image/s3,"s3://crabby-images/2d72e/2d72e24ee6bbf6e6bfb9a9b20e18b93442f239e9" alt="docs.rs"](https://docs.rs/vergen-gitcl)
[data:image/s3,"s3://crabby-images/8b271/8b271488e0c54bdaffee5f8ac986e8563f1cfc08" alt="Crates.io"](https://crates.io/crates/vergen-gitcl)
[data:image/s3,"s3://crabby-images/ff77a/ff77af6f6903ca61bea4f1cb8ae2d96aa495a54d" alt="Crates.io"](https://crates.io/crates/vergen-gitcl)
[data:image/s3,"s3://crabby-images/48500/4850081cee578fac1574dd944127f32d28196325" alt="Crates.io"](https://crates.io/crates/vergen-gitcl)
### vergen-gix
[data:image/s3,"s3://crabby-images/7a09b/7a09b13c6ff5eef83f7197461cc615e3c845dd1a" alt="docs.rs"](https://docs.rs/vergen-gix)
[data:image/s3,"s3://crabby-images/2dd58/2dd58c7263975175bf2e38a825e09b9eba46cf5b" alt="Crates.io"](https://crates.io/crates/vergen-gix)
[data:image/s3,"s3://crabby-images/a7c5f/a7c5f1f1a00430b2f1060ad6b385435ef191071b" alt="Crates.io"](https://crates.io/crates/vergen-gix)
[data:image/s3,"s3://crabby-images/fe868/fe868a53803e5df9eee9665c94ccec6b7012aa32" alt="Crates.io"](https://crates.io/crates/vergen-gix)
### vergen-pretty
[data:image/s3,"s3://crabby-images/53d1d/53d1df9953870ea8be75c31d248a4a6e4478d9f2" alt="docs.rs"](https://docs.rs/vergen-pretty)
[data:image/s3,"s3://crabby-images/ada35/ada35e405ab06d81a1ca6dae44a08f561485c80b" alt="Crates.io"](https://crates.io/crates/vergen-pretty)
[data:image/s3,"s3://crabby-images/03ac0/03ac0f6dd6023dabc7d1f429e538902240cfc71c" alt="Crates.io"](https://crates.io/crates/vergen-pretty)
[data:image/s3,"s3://crabby-images/90320/9032023fed1c9edfb27c3dc78d62752cb4617cc3" alt="Crates.io"](https://crates.io/crates/vergen-pretty)
## MSRV
The current minimum supported rust version is 1.81.0
## ⚠️ Notes on version 9 ⚠️
* Version 9 introduces 3 new libraries, `vergen-git2`, `vergen-gitcl`, and `vergen-gix` that will be versioned independently from `vergen`.
* The 3 new libraries are intended to be drop in replacements for `vergen` when you need to generate git based cargo build script instructions.
* The git based features have been removed from the base `vergen` library.
* `vergen` now contains the `build`, `cargo`, `rustc`, and `sysinfo` feature implementations. These features are re-exported by the new libraries allowing you to configure the output as you have previously.
* Version 9 introduces the `AddCustomEntries` trait. Implementing this trait allows you to include your own custom Cargo instructions, using `vergen` as the engine to generate them. See the [`AddCustomEntries`](https://docs.rs/vergen/9.0.0/vergen/trait.AddCustomEntries.html) docs for more information.
* The [version 8 branch](https://github.com/rustyhorde/vergen/tree/legacy/v8) will be maintained for some time.
### Why?
This was done to resolve issues with [Cargo feature unification](https://doc.rust-lang.org/cargo/reference/features.html#mutually-exclusive-features) and mutually exclusive features. Previous versions of `vergen` had 3 mutually exclusive features (`git2`, `gitcl`, and `gix`). Feature unification could cause compilation issues if you had included a dependency that also used `vergen` but had configured a different git feature. Splitting the git backends into separate libraries helps alleviate this issue.
## Migration from version 8
See the documentation at [MIGRATING_v8_to_v9.md](MIGRATING_v8_to_v9.md)
## Documentation
* [vergen](https://docs.rs/vergen/latest)
* [vergen-git2](https://docs.rs/vergen-git2/latest)
* [vergen-gitcl](https://docs.rs/vergen-gitcl/latest)
* [vergen-gix](https://docs.rs/vergen-gix/latest)
* [vergen-pretty](https://docs.rs/vergen-pretty/latest)
## Contributing
See the documentation at [CONTRIBUTING.md](CONTRIBUTING.md)
## License
Licensed under either of
* Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or https://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or https://opensource.org/licenses/MIT)
at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any
additional terms or conditions.