// `raw-dylib` is a Windows-specific attribute which emits idata sections for the items in the // attached extern block, // so they may be linked against without linking against an import library. // To learn more, read https://github.com/rust-lang/rfcs/blob/master/text/2627-raw-dylib-kind.md // This test is the simplest of the raw-dylib tests, simply smoke-testing that the feature // can be used to build an executable binary with an expected output with native C files // compiling into dynamic libraries. // See https://github.com/rust-lang/rust/pull/86419 //@ only-windows use run_make_support::{build_native_dynamic_lib, diff, run, rustc}; fn main() { rustc().crate_type("lib").crate_name("raw_dylib_test").input("lib.rs").run(); rustc().crate_type("bin").input("driver.rs").run(); rustc().crate_type("bin").crate_name("raw_dylib_test_bin").input("lib.rs").run(); build_native_dynamic_lib("extern_1"); build_native_dynamic_lib("extern_2"); let out_driver = run("driver").stdout_utf8(); let out_raw = run("raw_dylib_test_bin").stdout_utf8(); diff() .expected_file("output.txt") .actual_text("actual", out_driver) .normalize(r#"\r"#, "") .run(); diff().expected_file("output.txt").actual_text("actual", out_raw).normalize(r#"\r"#, "").run(); }