// This test checks the compatibility of the interaction between `--emit obj` and // `#[global_allocator]`, as it is now possible to invoke the latter without the // allocator shim since #86844. As this feature is unstable, it should fail if // --cfg check_feature_gate is passed. // See https://github.com/rust-lang/rust/pull/86844 //@ ignore-cross-compile // Reason: the compiled binary is executed use run_make_support::{cc, has_extension, has_prefix, run, rustc, shallow_find_files}; fn main() { rustc().input("foo.rs").crate_type("bin").emit("obj").panic("abort").run(); let libdir = rustc().print("target-libdir").run().stdout_utf8(); let libdir = libdir.trim(); let alloc_libs = shallow_find_files(&libdir, |path| { has_prefix(path, "liballoc-") && has_extension(path, "rlib") }); let core_libs = shallow_find_files(&libdir, |path| { has_prefix(path, "libcore-") && has_extension(path, "rlib") }); let compiler_builtins_libs = shallow_find_files(libdir, |path| { has_prefix(path, "libcompiler_builtins") && has_extension(path, "rlib") }); #[allow(unused_mut)] let mut platform_args = Vec::::new(); #[cfg(target_env = "msvc")] { platform_args.push("-MD".to_string()); // `/link` tells MSVC that the remaining arguments are linker options. platform_args.push("/link".to_string()); platform_args.push("vcruntime.lib".to_string()); platform_args.push("msvcrt.lib".to_string()); } cc().input("foo.o") .out_exe("foo") .args(&platform_args) .args(&alloc_libs) .args(&core_libs) .args(&compiler_builtins_libs) .run(); run("foo"); // Check that linking without __rust_no_alloc_shim_is_unstable_v2 defined fails rustc() .input("foo.rs") .crate_type("bin") .emit("obj") .panic("abort") .cfg("check_feature_gate") .run(); cc().input("foo.o") .out_exe("foo") .args(&platform_args) .args(&alloc_libs) .args(&core_libs) .args(&compiler_builtins_libs) .run_fail(); }