Merge "rust: Add rust_toolchain_library module."
This commit is contained in:
commit
9fdba2844e
3 changed files with 106 additions and 2 deletions
|
@ -38,6 +38,7 @@ bootstrap_go_package {
|
||||||
"strip.go",
|
"strip.go",
|
||||||
"test.go",
|
"test.go",
|
||||||
"testing.go",
|
"testing.go",
|
||||||
|
"toolchain_library.go",
|
||||||
],
|
],
|
||||||
testSrcs: [
|
testSrcs: [
|
||||||
"benchmark_test.go",
|
"benchmark_test.go",
|
||||||
|
|
|
@ -581,7 +581,7 @@ func (mod *Module) CrateName() string {
|
||||||
|
|
||||||
func (mod *Module) CcLibrary() bool {
|
func (mod *Module) CcLibrary() bool {
|
||||||
if mod.compiler != nil {
|
if mod.compiler != nil {
|
||||||
if _, ok := mod.compiler.(*libraryDecorator); ok {
|
if _, ok := mod.compiler.(libraryInterface); ok {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1554,7 +1554,7 @@ func (mod *Module) DepIsInSameApex(ctx android.BaseModuleContext, dep android.Mo
|
||||||
// Overrides ApexModule.IsInstallabeToApex()
|
// Overrides ApexModule.IsInstallabeToApex()
|
||||||
func (mod *Module) IsInstallableToApex() bool {
|
func (mod *Module) IsInstallableToApex() bool {
|
||||||
if mod.compiler != nil {
|
if mod.compiler != nil {
|
||||||
if lib, ok := mod.compiler.(*libraryDecorator); ok && (lib.shared() || lib.dylib()) {
|
if lib, ok := mod.compiler.(libraryInterface); ok && (lib.shared() || lib.dylib()) {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
if _, ok := mod.compiler.(*binaryDecorator); ok {
|
if _, ok := mod.compiler.(*binaryDecorator); ok {
|
||||||
|
|
103
rust/toolchain_library.go
Normal file
103
rust/toolchain_library.go
Normal file
|
@ -0,0 +1,103 @@
|
||||||
|
//
|
||||||
|
// Copyright (C) 2021 The Android Open Source Project
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
package rust
|
||||||
|
|
||||||
|
import (
|
||||||
|
"path"
|
||||||
|
|
||||||
|
"android/soong/android"
|
||||||
|
"android/soong/rust/config"
|
||||||
|
)
|
||||||
|
|
||||||
|
// This module is used to compile the rust toolchain libraries
|
||||||
|
// When RUST_PREBUILTS_VERSION is set, the library will generated
|
||||||
|
// from the given Rust version.
|
||||||
|
func init() {
|
||||||
|
android.RegisterModuleType("rust_toolchain_library",
|
||||||
|
rustToolchainLibraryFactory)
|
||||||
|
android.RegisterModuleType("rust_toolchain_library_rlib",
|
||||||
|
rustToolchainLibraryRlibFactory)
|
||||||
|
android.RegisterModuleType("rust_toolchain_library_dylib",
|
||||||
|
rustToolchainLibraryDylibFactory)
|
||||||
|
}
|
||||||
|
|
||||||
|
type toolchainLibraryProperties struct {
|
||||||
|
// path to the toolchain source, relative to the top of the toolchain source
|
||||||
|
Toolchain_src *string `android:"arch_variant"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type toolchainLibraryDecorator struct {
|
||||||
|
*libraryDecorator
|
||||||
|
Properties toolchainLibraryProperties
|
||||||
|
}
|
||||||
|
|
||||||
|
// rust_toolchain_library produces all rust variants.
|
||||||
|
func rustToolchainLibraryFactory() android.Module {
|
||||||
|
module, library := NewRustLibrary(android.HostAndDeviceSupported)
|
||||||
|
library.BuildOnlyRust()
|
||||||
|
|
||||||
|
return initToolchainLibrary(module, library)
|
||||||
|
}
|
||||||
|
|
||||||
|
// rust_toolchain_library_dylib produces a dylib.
|
||||||
|
func rustToolchainLibraryDylibFactory() android.Module {
|
||||||
|
module, library := NewRustLibrary(android.HostAndDeviceSupported)
|
||||||
|
library.BuildOnlyDylib()
|
||||||
|
|
||||||
|
return initToolchainLibrary(module, library)
|
||||||
|
}
|
||||||
|
|
||||||
|
// rust_toolchain_library_rlib produces an rlib.
|
||||||
|
func rustToolchainLibraryRlibFactory() android.Module {
|
||||||
|
module, library := NewRustLibrary(android.HostAndDeviceSupported)
|
||||||
|
library.BuildOnlyRlib()
|
||||||
|
|
||||||
|
return initToolchainLibrary(module, library)
|
||||||
|
}
|
||||||
|
|
||||||
|
func initToolchainLibrary(module *Module, library *libraryDecorator) android.Module {
|
||||||
|
toolchainLibrary := &toolchainLibraryDecorator{
|
||||||
|
libraryDecorator: library,
|
||||||
|
}
|
||||||
|
module.compiler = toolchainLibrary
|
||||||
|
module.AddProperties(&toolchainLibrary.Properties)
|
||||||
|
android.AddLoadHook(module, rustSetToolchainSource)
|
||||||
|
|
||||||
|
return module.Init()
|
||||||
|
}
|
||||||
|
|
||||||
|
func rustSetToolchainSource(ctx android.LoadHookContext) {
|
||||||
|
if toolchainLib, ok := ctx.Module().(*Module).compiler.(*toolchainLibraryDecorator); ok {
|
||||||
|
prefix := "linux-x86/" + GetRustPrebuiltVersion(ctx)
|
||||||
|
newSrcs := []string{path.Join(prefix, android.String(toolchainLib.Properties.Toolchain_src))}
|
||||||
|
|
||||||
|
type props struct {
|
||||||
|
Srcs []string
|
||||||
|
}
|
||||||
|
p := &props{}
|
||||||
|
p.Srcs = newSrcs
|
||||||
|
ctx.AppendProperties(p)
|
||||||
|
|
||||||
|
} else {
|
||||||
|
ctx.ModuleErrorf("Called rustSetToolchainSource on a non-Rust Module.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetRustPrebuiltVersion returns the RUST_PREBUILTS_VERSION env var, or the default version if it is not defined.
|
||||||
|
func GetRustPrebuiltVersion(ctx android.LoadHookContext) string {
|
||||||
|
return ctx.AConfig().GetenvWithDefault("RUST_PREBUILTS_VERSION", config.RustDefaultVersion)
|
||||||
|
}
|
Loading…
Reference in a new issue