forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of rust-lang#128936 - bjorn3:fix_thin_archive_reading, r=j…
…ieyouxu Support reading thin archives in ArArchiveBuilder And switch to using ArArchiveBuilder with the LLVM backend too now that all regressions are fixed. Fixes rust-lang#107407 Fixes rust-lang#107162 rust-lang#107495 has been fixed in a previous PR already.
- Loading branch information
Showing
8 changed files
with
63 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
fn main() { | ||
unsafe { | ||
rust_lib::simple_fn(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
// Regression test for https://github.com/rust-lang/rust/issues/107407 which | ||
// checks that rustc can read thin archive. Before the object crate added thin | ||
// archive support rustc would add emit object files to the staticlib and after | ||
// the object crate added thin archive support it would previously crash the | ||
// compiler due to a missing special case for thin archive members. | ||
use run_make_support::{llvm_ar, path, rfs, rust_lib_name, rustc, static_lib_name}; | ||
|
||
fn main() { | ||
rfs::create_dir("archive"); | ||
|
||
// Build a thin archive | ||
rustc().input("simple_obj.rs").emit("obj").output("archive/simple_obj.o").run(); | ||
llvm_ar() | ||
.obj_to_thin_ar() | ||
.output_input(path("archive").join(static_lib_name("thin_archive")), "archive/simple_obj.o") | ||
.run(); | ||
|
||
// Build an rlib which includes the members of this thin archive | ||
rustc().input("rust_lib.rs").library_search_path("archive").run(); | ||
|
||
// Build a binary which requires a symbol from the thin archive | ||
rustc().input("bin.rs").extern_("rust_lib", rust_lib_name("rust_lib")).run(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
#![crate_type = "rlib"] | ||
|
||
#[link(name = "thin_archive", kind = "static")] | ||
extern "C" { | ||
pub fn simple_fn(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
#![crate_type = "staticlib"] | ||
|
||
#[no_mangle] | ||
extern "C" fn simple_fn() {} |