| // The `#[link(cfg(..))]` annotation means that the `#[link]` |
| // directive is only active in a compilation unit if that `cfg` value is satisfied. |
| // For example, when compiling an rlib, these directives are just encoded and |
| // ignored for dylibs, and all staticlibs are continued to be put into the rlib as |
| // usual. When placing that rlib into a staticlib, executable, or dylib, however, |
| // the `cfg` is evaluated *as if it were defined in the final artifact* and the |
| // library is decided to be linked or not. |
| // This test exercises this new feature by testing it with no dependencies, then |
| // with only dynamic libraries, then with both a staticlib and dylibs. Compilation |
| // and execution should be successful. |
| // See https://github.com/rust-lang/rust/pull/37545 |
| |
| //@ ignore-cross-compile |
| // Reason: the compiled binary is executed |
| |
| use run_make_support::{bare_rustc, build_native_dynamic_lib, build_native_static_lib, run, rustc}; |
| |
| fn main() { |
| build_native_dynamic_lib("return1"); |
| build_native_dynamic_lib("return2"); |
| build_native_static_lib("return3"); |
| bare_rustc() |
| .print("cfg") |
| .target("x86_64-unknown-linux-musl") |
| .run() |
| .assert_stdout_contains("crt-static"); |
| rustc().input("no-deps.rs").cfg("foo").run(); |
| run("no-deps"); |
| rustc().input("no-deps.rs").cfg("bar").run(); |
| run("no-deps"); |
| |
| rustc().input("dep.rs").run(); |
| rustc().input("with-deps.rs").cfg("foo").run(); |
| run("with-deps"); |
| rustc().input("with-deps.rs").cfg("bar").run(); |
| run("with-deps"); |
| |
| rustc().input("dep-with-staticlib.rs").run(); |
| rustc().input("with-staticlib-deps.rs").cfg("foo").run(); |
| run("with-staticlib-deps"); |
| rustc().input("with-staticlib-deps.rs").cfg("bar").run(); |
| run("with-staticlib-deps"); |
| } |