diff options
author | 2022-08-10 20:25:50 +0000 | |
---|---|---|
committer | 2022-08-10 20:25:50 +0000 | |
commit | e94f3e73ddaa44e8b6f5badf8c06a144d2c7bad6 (patch) | |
tree | 56c025bc93ec205ca8f4041069faf622bd0f02d7 | |
parent | 199c18850233f3d07f65c7be3bfa70878cc6c345 (diff) |
Revert^4 "rust: Only allow bindgen to produce `rlib`s."
199c18850233f3d07f65c7be3bfa70878cc6c345
Change-Id: I28b353fa89354cc572806b2274169342a473a03c
-rw-r--r-- | rust/bindgen.go | 10 | ||||
-rw-r--r-- | rust/protobuf.go | 2 | ||||
-rw-r--r-- | rust/source_provider.go | 5 |
3 files changed, 14 insertions, 3 deletions
diff --git a/rust/bindgen.go b/rust/bindgen.go index 72cc894cc..0199d3a37 100644 --- a/rust/bindgen.go +++ b/rust/bindgen.go @@ -299,7 +299,15 @@ func NewRustBindgen(hod android.HostOrDeviceSupported) (*Module, *bindgenDecorat ClangProperties: cc.RustBindgenClangProperties{}, } - module := NewSourceProviderModule(hod, bindgen, false) + module := NewSourceProviderModule(hod, bindgen, false, true) + + android.AddLoadHook(module, func(ctx android.LoadHookContext) { + type stub_props struct { + Visibility []string + } + props := &stub_props{[]string{":__subpackages__"}} + ctx.PrependProperties(props) + }) return module, bindgen } diff --git a/rust/protobuf.go b/rust/protobuf.go index 9fe27c4c9..88e80fe35 100644 --- a/rust/protobuf.go +++ b/rust/protobuf.go @@ -238,7 +238,7 @@ func NewRustProtobuf(hod android.HostOrDeviceSupported) (*Module, *protobufDecor Properties: ProtobufProperties{}, } - module := NewSourceProviderModule(hod, protobuf, false) + module := NewSourceProviderModule(hod, protobuf, false, false) return module, protobuf } diff --git a/rust/source_provider.go b/rust/source_provider.go index 7719611d5..4f8d22b1f 100644 --- a/rust/source_provider.go +++ b/rust/source_provider.go @@ -65,9 +65,12 @@ func NewSourceProvider() *BaseSourceProvider { } } -func NewSourceProviderModule(hod android.HostOrDeviceSupported, sourceProvider SourceProvider, enableLints bool) *Module { +func NewSourceProviderModule(hod android.HostOrDeviceSupported, sourceProvider SourceProvider, enableLints bool, rlibOnly bool) *Module { _, library := NewRustLibrary(hod) library.BuildOnlyRust() + if rlibOnly { + library.BuildOnlyRlib() + } library.sourceProvider = sourceProvider module := newModule(hod, android.MultilibBoth) |