cargo-emit 0.2.1

Talk to Cargo easily at build time.
Documentation
/// Tells Cargo to enable a `$feature`.
///
/// This is equivalent to:
///
/// ```
/// println!("cargo:rustc-cfg=$feature");
/// ```
///
/// # Examples
///
/// Useful for conditionally enabling certain code to run.
///
/// ```
/// # struct Cargo;
/// # impl Cargo {
/// #   fn can_bench(&self) -> bool { true }
/// # }
/// # let cargo = Cargo;
/// if cargo.can_bench() {
///     cargo_emit::rustc_cfg!("bench");
/// }
/// ```
///
/// or, in case you want it to emit to a custom stream:
///
/// ```
/// # struct Cargo;
/// # impl Cargo {
/// #   fn can_bench(&self) -> bool { true }
/// # }
/// # let cargo = Cargo;
/// let mut stdout = std::io::stdout();    
/// if cargo.can_bench() {
///     cargo_emit::rustc_cfg!(
///         to: stdout,
///         "bench"
///     );
/// }
/// ```
///
/// Then outside of `build.rs`:
///
/// ```
/// #[cfg(bench)]
/// mod benches {
///     // ...
/// }
/// ```
#[macro_export]
macro_rules! rustc_cfg {
    (to: $stream:expr, $feature:expr $(, $($args:tt)*)?) => {
        $crate::pair!(to: $stream, "rustc-cfg", $feature $(, $($args)+)?);
    };
    ($feature:expr $(, $($args:tt)*)?) => {
        $crate::rustc_cfg!(to: std::io::stdout(), $feature $(, $($args)+)?);
    };
}

#[cfg(test)]
mod tests {
    #[test]
    fn literal() {
        insta::assert_display_snapshot!(
            crate::capture_output(|output| {
                crate::rustc_cfg!(
                    to: output,
                    "CFG"
                );
            }),
            @"cargo:rustc-cfg=CFG\n"
        );
    }

    #[test]
    fn formatted() {
        insta::assert_display_snapshot!(
            crate::capture_output(|output| {
                crate::rustc_cfg!(
                    to: output,
                    "{}", "CFG"
                );
            }),
            @"cargo:rustc-cfg=CFG\n"
        );
    }
}