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"
        );
    }
}