mirror of https://github.com/rust-lang/rust
30 lines
1.3 KiB
Rust
30 lines
1.3 KiB
Rust
// `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();
|
|
}
|