#git-commit #build #git-version #tree #record #information #proc-macro

no-std build git-testament

Record git working tree status when compiling your crate

13 releases

0.2.5 Sep 20, 2023
0.2.4 Jan 18, 2023
0.2.2 Dec 30, 2022
0.2.1 Nov 8, 2021
0.1.6 May 7, 2019

#27 in Build Utils

Download history 2126/week @ 2023-12-07 1605/week @ 2023-12-14 1372/week @ 2023-12-21 1603/week @ 2023-12-28 1656/week @ 2024-01-04 1390/week @ 2024-01-11 2092/week @ 2024-01-18 1473/week @ 2024-01-25 1884/week @ 2024-02-01 2501/week @ 2024-02-08 2901/week @ 2024-02-15 1698/week @ 2024-02-22 1675/week @ 2024-02-29 2038/week @ 2024-03-07 1811/week @ 2024-03-14 1689/week @ 2024-03-21

7,397 downloads per month
Used in 29 crates (17 directly)

BSD-3-Clause

22KB
219 lines

Git Testament

BSD 3 Clause Main build status Latest docs Crates.IO

git-testament is a library to embed a testament as to the state of a git working tree during the build of a Rust program. It uses the power of procedural macros to embed commit, tag, and working-tree-state information into your program when it is built. This can then be used to report version information.

use git_testament::{git_testament, render_testament};

git_testament!(TESTAMENT);

fn main() {
    println!("My version information: {}", render_testament!(TESTAMENT));
}

Reproducible builds

In the case that your build is not being done from a Git repository, you still want your testament to be useful to your users. Reproducibility of the binary is critical in that case. The Reproducible Builds team have defined a mechanism for this known as SOURCE_DATE_EPOCH which is an environment variable which can be set to ensure the build date is fixed for reproducibilty reasons. If you have no repo (or a repo but no commit) then git_testament!() will use the SOURCE_DATE_EPOCH environment variable (if present and parseable as a number of seconds since the UNIX epoch) to override now.

Use in no_std scenarios

This crate does not link to anything in the standard library, but it does rely by default on the alloc library being available. Disabling the alloc feature allows the crate to work in no_std environments where the alloc library is not available. You can still generate a GitTestament struct though it'll be less easy to work with. Instead it'd be recommended to use the git_testament_macros!() macro instead which provides a set of macros which produce string constants to use. This is less flexible/capable but can sometimes be easier to work with in these kinds of situations.

Dependencies

~1–1.6MB
~34K SLoC