所以我写了一个go文件,它将一个库动态地追加到apex_defaults-> multilib-> first-> native_shared_libs;可以检查Android.bp
的完整代码。但是,我无法像其他生成的lib .so文件那样在out目录中看到已编译的.so文件。
详细说明:
我想将名为“ libabcxtractor”的库添加到数组here;为此,我写了一个native_shared_libs文件(由Google推荐),条件如下:
.go
为了使上述条件在构建时被选择,我已经更新了我的package my_apex
import (
"android/soong/android"
"android/soong/apex"
"fmt"
"strings"
)
func globalFlags(ctx android.BaseContext) []string {
var native_shared_libs []string
if(strings.Contains(ctx.AConfig().DeviceName(), "my_apex_device")){
fmt.Println("Some log to verify condition is getting executed......")
native_shared_libs = append(native_shared_libs, "libabcextractor")
}
return native_shared_libs
}
func myApexFlagsDefaults(ctx android.LoadHookContext) {
type props struct {
Multilib struct {
First struct {
native_shared_libs []string
}
}
}
p := &props{}
p.Multilib.First.native_shared_libs = globalFlags(ctx)
ctx.AppendProperties(p)
}
func myApexFlagsDefaultsFactory() android.Module {
module := apex.DefaultsFactory()
android.AddLoadHook(module, myApexFlagsDefaults)
return module
}
func init() {
fmt.Println("Registering module type....")
android.RegisterModuleType("my_apex_defaults", myApexFlagsDefaultsFactory)
}
文件,如下所示:
Android.bp
执行make命令时,我可以看到它输入了条件语句;日志正在打印。我通过检查路径bootstrap_go_package {
name: "soong-my_apex",
pkgPath: "frameworks/av/apex/build",
deps: [ "soong-apex" ],
srcs: [ "my_apex.go", ],
pluginFor: ["soong_build"],
}
my_apex_defaults {
name: "my_apex",
}
apex_defaults {
name: "com.android.media-defaults",
java_libs: ["updatable-media"],
defaults: ["my_apex",] //THIS IS TO INCLUDE GO IMPLEMENTATION
multilib: {
来验证我的.go
文件是否已编译来进一步研究。在那。但是,尚未生成out/soong/.bootstrap/soong-my_apex/pkg/frameworks/av/apex/build.a
的".so"
文件。任何帮助都会很棒。
编辑:libabcextractor
是位于预构建路径中的供应商库。如果我尝试使用属于AOSP代码一部分并且已经存在于现有libabcextractor
数组中的任何其他库,则它们也不适用于它们。从这里开始,由于没有适当的文档,我无法进一步调试。
Go中的Reflection只能访问导出的结构字段,这些结构字段以大写字母开头。在您的native_static_libs
结构中,First
未导出,因此无法使用反射进行访问。
由于构建过程使用反射来访问native_shared_libs
结构,因此无法从中找到信息。您可以像这样更改它:
props