From 7e741cca301006b5e5801e14a180a8b346b2aa83 Mon Sep 17 00:00:00 2001 From: Ivan Lozano Date: Fri, 19 Jun 2020 12:32:30 -0400 Subject: [PATCH] [Rust] cdylibs can now link against dylibs. Bug: 144861059 Test: cd external/rust/crates; mma Test: Manual verification through ldd that libstd is a dependency Change-Id: I603cf519215317aa8c400cd0f6ebb1b58f5bcf15 --- rust/library.go | 4 ++-- rust/library_test.go | 20 +++++++++++++++----- 2 files changed, 17 insertions(+), 7 deletions(-) diff --git a/rust/library.go b/rust/library.go index 2e5126639..ba5546cdd 100644 --- a/rust/library.go +++ b/rust/library.go @@ -311,8 +311,8 @@ func (library *libraryDecorator) compilerProps() []interface{} { func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps { - // TODO(b/144861059) Remove if C libraries support dylib linkage in the future. - if !ctx.Host() && (library.static() || library.shared()) { + // TODO(b/155498724) Remove if C static libraries no longer require libstd as an rlib dependency. + if !ctx.Host() && library.static() { library.setNoStdlibs() for _, stdlib := range config.Stdlibs { deps.Rlibs = append(deps.Rlibs, stdlib+".static") diff --git a/rust/library_test.go b/rust/library_test.go index 37dd5414c..9d2f6c00a 100644 --- a/rust/library_test.go +++ b/rust/library_test.go @@ -17,6 +17,8 @@ package rust import ( "strings" "testing" + + "android/soong/android" ) // Test that variants are being generated correctly, and that crate-types are correct. @@ -115,16 +117,24 @@ func TestValidateLibraryStem(t *testing.T) { } -func TestSharedLibraryFlags(t *testing.T) { +func TestSharedLibrary(t *testing.T) { ctx := testRust(t, ` - rust_library_host { + rust_library { name: "libfoo", srcs: ["foo.rs"], crate_name: "foo", }`) - libfooShared := ctx.ModuleForTests("libfoo", "linux_glibc_x86_64_shared").Output("libfoo.so") - if !strings.Contains(libfooShared.Args["linkFlags"], "-Wl,-soname=libfoo.so") { - t.Errorf("missing expected -Wl,-soname linker flag for libfoo shared lib, linkFlags: %#v", libfooShared.Args["linkFlags"]) + libfoo := ctx.ModuleForTests("libfoo", "android_arm64_armv8-a_shared") + + libfooOutput := libfoo.Output("libfoo.so") + if !strings.Contains(libfooOutput.Args["linkFlags"], "-Wl,-soname=libfoo.so") { + t.Errorf("missing expected -Wl,-soname linker flag for libfoo shared lib, linkFlags: %#v", + libfooOutput.Args["linkFlags"]) + } + + if !android.InList("libstd", libfoo.Module().(*Module).Properties.AndroidMkDylibs) { + t.Errorf("Non-static libstd dylib expected to be a dependency of Rust shared libraries. Dylib deps are: %#v", + libfoo.Module().(*Module).Properties.AndroidMkDylibs) } }