cargo_emit/warning.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
/// Tells Cargo to print the formatted `warning` message.
///
/// This is equivalent to:
///
/// ```
/// println!("cargo:warning=$args");
/// ```
///
/// # Examples
///
/// Useful for showing when something expected (but not critical) has failed.
///
/// ```
/// match std::env::current_dir() {
/// Ok(dir) => { /* ... */ }
/// Err(error) => cargo_emit::warning!(
/// "Something suspicious is happening: {}",
/// error,
/// ),
/// }
/// ```
///
/// or, in case you want it to emit to a custom stream:
///
/// ```
/// let mut stdout = std::io::stdout();
/// match std::env::current_dir() {
/// Ok(dir) => { /* ... */ }
/// Err(error) => cargo_emit::warning!(
/// to: stdout,
/// "Something suspicious is happening: {}",
/// error,
/// ),
/// }
/// ```
///
/// Assuming you're building `my-crate`, you will see:
///
/// ```sh
/// $ cargo build
/// Compiling my-crate v0.1.0 (/path/to/my-crate)
/// warning: Something suspicious is happening: ...
/// ```
#[macro_export]
macro_rules! warning {
(to: $stream:expr, $($args:tt)+) => {
$crate::pair!(to: $stream, "warning", $($args)+)
};
($($args:tt)+) => {
$crate::warning!(to: std::io::stdout(), $($args)+)
};
}
#[cfg(test)]
mod tests {
#[test]
fn single_literal() {
insta::assert_display_snapshot!(
crate::capture_output(|output| {
crate::warning!(
to: output,
"WARNING"
);
}),
@"cargo:warning=WARNING\n"
);
}
#[test]
fn single_formatted_by_index() {
// Formatted argument:
insta::assert_display_snapshot!(
crate::capture_output(|output| {
crate::warning!(
to: output,
"{}", "WARNING"
);
}),
@"cargo:warning=WARNING\n"
);
}
#[test]
fn single_formatted_by_key() {
// Formatted argument:
insta::assert_display_snapshot!(
crate::capture_output(|output| {
crate::warning!(
to: output,
"{warning}", warning = "WARNING"
);
}),
@"cargo:warning=WARNING\n"
);
}
}