pub struct Emitter { /* private fields */ }Expand description
The Emitter will emit cargo instructions (i.e. cargo:rustc-env=NAME=VALUE)
base on the configuration you enable.
Implementations§
Source§impl Emitter
 
impl Emitter
Sourcepub fn idempotent(&mut self) -> &mut Emitter
 
pub fn idempotent(&mut self) -> &mut Emitter
Enable the idempotent feature
NOTE - This feature can also be enabled via the VERGEN_IDEMPOTENT
environment variable.
When this feature is enabled, certain vergen output (i.e. timestamps, sysinfo)
will be set to an idempotent default.  This will allow systems that
depend on deterministic builds to override user requested vergen
impurities.  This will mainly allow for package maintainers to build
packages that depend on vergen in a deterministic manner.
See this issue for more details
| Variable | Sample | 
|---|---|
| VERGEN_BUILD_DATE | VERGEN_IDEMPOTENT_OUTPUT | 
| VERGEN_BUILD_TIMESTAMP | VERGEN_IDEMPOTENT_OUTPUT | 
§Example
Emitter::new().idempotent().emit()?;
// or
// set::env("VERGEN_IDEMPOTENT", "true");
Emitter::new().emit()?;Sourcepub fn fail_on_error(&mut self) -> &mut Emitter
 
pub fn fail_on_error(&mut self) -> &mut Emitter
Enable the fail_on_error feature
By default vergen will emit the instructions you requested.  If for some
reason those instructions cannot be generated correctly, placeholder values
will be used instead.   vergen will also emit cargo:warning
instructions notifying you this has happened.
For example, if you configure vergen to emit VERGEN_GIT_* instructions and
you run a build from a source tarball with no .git directory, the instructions
will be populated with placeholder values, rather than information gleaned through git.
You can turn off this behavior by enabling fail_on_error.
§Example
Emitter::new().fail_on_error().emit()?;Sourcepub fn quiet(&mut self) -> &mut Emitter
 
pub fn quiet(&mut self) -> &mut Emitter
Enable the quiet feature
Suppress the emission of the cargo:warning instructions.
§Example
Emitter::new().quiet().emit()?;Sourcepub fn custom_build_rs(&mut self, path: &'static str) -> &mut Emitter
 
pub fn custom_build_rs(&mut self, path: &'static str) -> &mut Emitter
Set a custom build.rs path if you are using a non-standard path
By default vergen will use build.rs as the build path for the
cargo:rerun-if-changed emit.  You can specify a custom build.rs
path here if you have changed this default
§Example
Emitter::new().custom_build_rs("my/custom/build.rs").emit()?;Sourcepub fn add_instructions(&mut self, gen: &dyn Add) -> Result<&mut Emitter, Error>
 
pub fn add_instructions(&mut self, gen: &dyn Add) -> Result<&mut Emitter, Error>
Add a set of instructions to the emitter output
§Errors
Sourcepub fn add_custom_instructions<K, V>(
    &mut self,
    gen: &impl AddCustom<K, V>,
) -> Result<&mut Emitter, Error>
 
pub fn add_custom_instructions<K, V>( &mut self, gen: &impl AddCustom<K, V>, ) -> Result<&mut Emitter, Error>
Add a set of custom instructions to the emitter output
§Errors
Errors may be generated if fail_on_error has been configured.
Sourcepub fn emit(&self) -> Result<(), Error>
 
pub fn emit(&self) -> Result<(), Error>
Emit cargo instructions from your build script
- Will emit cargo:rustc-env=VAR=VALUEfor each feature you have enabled.
- Will emit cargo:rerun-if-changed=PATHif the git feature is enabled. This is done to ensure any git variables are regenerated when commits are made.
- Can emit cargo:warningoutputs if thefail_on_errorfeature is not enabled and the requested variable is defaulted through error or theidempotentflag.
§Errors
- The writeln!macro can throw astd::io::Error
§Example
let emitter = Emitter::default().emit()?;§Sample Output
NOTE - You won’t see this output unless you invoke cargo with the -vv flag.
The instruction output is not displayed by default.
cargo:rustc-env=VERGEN_BUILD_DATE=2023-01-04
cargo:rustc-env=VERGEN_BUILD_TIMESTAMP=2023-01-04T15:38:11.097507114Z
cargo:rustc-env=VERGEN_CARGO_DEBUG=true
cargo:rustc-env=VERGEN_CARGO_FEATURES=build,git
cargo:rustc-env=VERGEN_CARGO_OPT_LEVEL=1
cargo:rustc-env=VERGEN_CARGO_TARGET_TRIPLE=x86_64-unknown-linux-gnu
cargo:rustc-env=VERGEN_GIT_BRANCH=feature/version8
cargo:rustc-env=VERGEN_GIT_COMMIT_AUTHOR_EMAIL=your@email.com
cargo:rustc-env=VERGEN_GIT_COMMIT_AUTHOR_NAME=Yoda
cargo:rustc-env=VERGEN_GIT_COMMIT_COUNT=476
cargo:rustc-env=VERGEN_GIT_COMMIT_DATE=2023-01-03
cargo:rustc-env=VERGEN_GIT_COMMIT_MESSAGE=The best message
cargo:rustc-env=VERGEN_GIT_COMMIT_TIMESTAMP=2023-01-03T14:08:12.000000000-05:00
cargo:rustc-env=VERGEN_GIT_DESCRIBE=7.4.4-103-g53ae8a6
cargo:rustc-env=VERGEN_GIT_SHA=53ae8a69ab7917a2909af40f2e5d015f5b29ae28
cargo:rustc-env=VERGEN_RUSTC_CHANNEL=nightly
cargo:rustc-env=VERGEN_RUSTC_COMMIT_DATE=2023-01-03
cargo:rustc-env=VERGEN_RUSTC_COMMIT_HASH=c7572670a1302f5c7e245d069200e22da9df0316
cargo:rustc-env=VERGEN_RUSTC_HOST_TRIPLE=x86_64-unknown-linux-gnu
cargo:rustc-env=VERGEN_RUSTC_LLVM_VERSION=15.0
cargo:rustc-env=VERGEN_RUSTC_SEMVER=1.68.0-nightly
cargo:rustc-env=VERGEN_SYSINFO_NAME=Arch Linux
cargo:rustc-env=VERGEN_SYSINFO_OS_VERSION=Linux  Arch Linux
cargo:rustc-env=VERGEN_SYSINFO_USER=jozias
cargo:rustc-env=VERGEN_SYSINFO_TOTAL_MEMORY=31 GiB
cargo:rustc-env=VERGEN_SYSINFO_CPU_VENDOR=AuthenticAMD
cargo:rustc-env=VERGEN_SYSINFO_CPU_CORE_COUNT=8
cargo:rustc-env=VERGEN_SYSINFO_CPU_NAME=cpu0,cpu1,cpu2,cpu3,cpu4,cpu5,cpu6,cpu7
cargo:rustc-env=VERGEN_SYSINFO_CPU_BRAND=AMD Ryzen Threadripper 1900X 8-Core Processor
cargo:rustc-env=VERGEN_SYSINFO_CPU_FREQUENCY=3792
cargo:rerun-if-changed=.git/HEAD
cargo:rerun-if-changed=.git/refs/heads/feature/version8
cargo:rerun-if-changed=build.rs
cargo:rerun-if-env-changed=VERGEN_IDEMPOTENT
cargo:rerun-if-env-changed=SOURCE_DATE_EPOCHSourcepub fn emit_and_set(&self) -> Result<(), Error>
 Available on crate feature emit_and_set only.
pub fn emit_and_set(&self) -> Result<(), Error>
emit_and_set only.Emit cargo instructions from your build script and set environment variables for use in build.rs
- Will emit cargo:rustc-env=VAR=VALUEfor each feature you have enabled.
- Will emit cargo:rerun-if-changed=PATHif the git feature is enabled. This is done to ensure any git variables are regenerated when commits are made.
- Can emit cargo:warningoutputs if thefail_on_errorfeature is not enabled and the requested variable is defaulted through error or theidempotentflag.
§Errors
- The writeln!macro can throw astd::io::Error
§Example
Emitter::new().emit_and_set()?;Trait Implementations§
impl StructuralPartialEq for Emitter
Auto Trait Implementations§
impl Freeze for Emitter
impl RefUnwindSafe for Emitter
impl Send for Emitter
impl Sync for Emitter
impl Unpin for Emitter
impl UnwindSafe for Emitter
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more