cargo_emit/rustc_link_arg_bin.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
/// Tells Cargo to pass the `-C link-arg=$flag` option to the compiler,
/// but only when building the binary target with name `$bin`.
/// Its usage is highly platform specific.
/// It is useful to set a linker script or other linker options.
///
/// This is equivalent to:
///
/// ```
/// println!("cargo:rustc-link-arg-bin=$bin=$flag");
/// ```
///
/// # Examples
///
/// ```
/// cargo_emit::rustc_link_arg_bin!(
/// "hello_world" => "-Wall"
/// );
/// ```
///
/// or, in case you want it to emit to a custom stream:
///
/// ```
/// let mut stdout = std::io::stdout();
/// cargo_emit::rustc_link_arg_bin!(
/// to: stdout,
/// "hello_world" => "-Wall"
/// );
/// ```
#[macro_export]
macro_rules! rustc_link_arg_bin {
(to: $stream:expr, $bin:expr => $flags:expr $(,)?) => {
$crate::pair!(to: $stream, "rustc-link-arg-bin", "{}={}", $bin, $flags);
};
(to: $stream:expr, $($bin:expr=> $flags:expr),+ $(,)?) => { {
$($crate::rustc_link_arg_bin!(to: $stream, $bin => $flags);)+
} };
($bin:expr => $flags:expr $(,)?) => {
$crate::rustc_link_arg_bin!(to: std::io::stdout(), $bin => $flags);
};
($($bin:expr=> $flags:expr),+ $(,)?) => { {
$crate::rustc_link_arg_bin!(to: std::io::stdout(), $($bin=> $flags),+);
} };
}
#[cfg(test)]
mod tests {
#[test]
fn single() {
insta::assert_display_snapshot!(
crate::capture_output(|output| {
crate::rustc_link_arg_bin!(
to: output,
"BIN" => "FLAGS"
);
}),
@"cargo:rustc-link-arg-bin=BIN=FLAGS
"
);
}
#[test]
fn multiple() {
insta::assert_display_snapshot!(
crate::capture_output(|output| {
crate::rustc_link_arg_bin!(
to: output,
"BIN1" => "FLAGS1",
"BIN2" => "FLAGS2",
);
}),
@r###"
cargo:rustc-link-arg-bin=BIN1=FLAGS1
cargo:rustc-link-arg-bin=BIN2=FLAGS2
"###
);
}
}