#git-repository #build #cargo-build #revision #build-script #embed #io

build crate-git-revision

Embed git revision into crates built and published

5 releases

0.0.6 Feb 17, 2023
0.0.5 Jan 3, 2023
0.0.4 Dec 5, 2022
0.0.3 Nov 28, 2022
0.0.2 Oct 19, 2022

#114 in Build Utils

Download history 2666/week @ 2024-01-05 2460/week @ 2024-01-12 2362/week @ 2024-01-19 2223/week @ 2024-01-26 2833/week @ 2024-02-02 2699/week @ 2024-02-09 2817/week @ 2024-02-16 2805/week @ 2024-02-23 2565/week @ 2024-03-01 2466/week @ 2024-03-08 1788/week @ 2024-03-15 3273/week @ 2024-03-22 2187/week @ 2024-03-29 3689/week @ 2024-04-05 4149/week @ 2024-04-12 2968/week @ 2024-04-19

13,567 downloads per month
Used in 63 crates (13 directly)

Apache-2.0

13KB
197 lines

crate-git-revision

Embed the git revision of a crate in its build.

Supports embedding the version from a local or remote git repository the build is occurring in, as well as when cargo install or depending on a crate published to crates.io.

It extracts the git revision in two ways:

  • From the .cargo_vcs_info.json file embedded in published crates.
  • From the git repository the build is occurring from in unpublished crates.

Injects an environment variable GIT_REVISION into the build that contains the full git revision, with a -dirty suffix if the working directory is dirty.

Requires the use of a build.rs build script. See Build Scripts for more details on how Rust build scripts work.

Examples

Add the following to the crate's Cargo.toml file:

[build_dependencies]
crate-git-revision = "0.0.2"

Add the following to the crate's build.rs file:

crate_git_revision::init();

Add the following to the crate's lib.rs or main.rs file:

pub const GIT_REVISION: &str = env!("GIT_REVISION");

License: Apache-2.0

Dependencies

~0.7–1.4MB
~33K SLoC