Merge "Create prebuilt api modules in load hook not mutator" into rvc-dev am: fc5608ec80
Change-Id: Iae8feeff7d5b52dde71fcca93cdc767813e2e1ab
This commit is contained in:
commit
efdad0fc18
1 changed files with 15 additions and 13 deletions
|
@ -28,10 +28,6 @@ func init() {
|
||||||
|
|
||||||
func RegisterPrebuiltApisBuildComponents(ctx android.RegistrationContext) {
|
func RegisterPrebuiltApisBuildComponents(ctx android.RegistrationContext) {
|
||||||
ctx.RegisterModuleType("prebuilt_apis", PrebuiltApisFactory)
|
ctx.RegisterModuleType("prebuilt_apis", PrebuiltApisFactory)
|
||||||
|
|
||||||
ctx.PreArchMutators(func(ctx android.RegisterMutatorsContext) {
|
|
||||||
ctx.TopDown("prebuilt_apis", PrebuiltApisMutator).Parallel()
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type prebuiltApisProperties struct {
|
type prebuiltApisProperties struct {
|
||||||
|
@ -48,7 +44,7 @@ func (module *prebuiltApis) GenerateAndroidBuildActions(ctx android.ModuleContex
|
||||||
// no need to implement
|
// no need to implement
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseJarPath(ctx android.BaseModuleContext, path string) (module string, apiver string, scope string) {
|
func parseJarPath(path string) (module string, apiver string, scope string) {
|
||||||
elements := strings.Split(path, "/")
|
elements := strings.Split(path, "/")
|
||||||
|
|
||||||
apiver = elements[0]
|
apiver = elements[0]
|
||||||
|
@ -58,7 +54,7 @@ func parseJarPath(ctx android.BaseModuleContext, path string) (module string, ap
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseApiFilePath(ctx android.BaseModuleContext, path string) (module string, apiver string, scope string) {
|
func parseApiFilePath(ctx android.LoadHookContext, path string) (module string, apiver string, scope string) {
|
||||||
elements := strings.Split(path, "/")
|
elements := strings.Split(path, "/")
|
||||||
apiver = elements[0]
|
apiver = elements[0]
|
||||||
|
|
||||||
|
@ -73,7 +69,7 @@ func parseApiFilePath(ctx android.BaseModuleContext, path string) (module string
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func createImport(mctx android.TopDownMutatorContext, module string, scope string, apiver string, path string) {
|
func createImport(mctx android.LoadHookContext, module string, scope string, apiver string, path string) {
|
||||||
props := struct {
|
props := struct {
|
||||||
Name *string
|
Name *string
|
||||||
Jars []string
|
Jars []string
|
||||||
|
@ -89,7 +85,7 @@ func createImport(mctx android.TopDownMutatorContext, module string, scope strin
|
||||||
mctx.CreateModule(ImportFactory, &props)
|
mctx.CreateModule(ImportFactory, &props)
|
||||||
}
|
}
|
||||||
|
|
||||||
func createFilegroup(mctx android.TopDownMutatorContext, module string, scope string, apiver string, path string) {
|
func createFilegroup(mctx android.LoadHookContext, module string, scope string, apiver string, path string) {
|
||||||
fgName := module + ".api." + scope + "." + apiver
|
fgName := module + ".api." + scope + "." + apiver
|
||||||
filegroupProps := struct {
|
filegroupProps := struct {
|
||||||
Name *string
|
Name *string
|
||||||
|
@ -100,7 +96,7 @@ func createFilegroup(mctx android.TopDownMutatorContext, module string, scope st
|
||||||
mctx.CreateModule(android.FileGroupFactory, &filegroupProps)
|
mctx.CreateModule(android.FileGroupFactory, &filegroupProps)
|
||||||
}
|
}
|
||||||
|
|
||||||
func getPrebuiltFiles(mctx android.TopDownMutatorContext, name string) []string {
|
func getPrebuiltFiles(mctx android.LoadHookContext, name string) []string {
|
||||||
mydir := mctx.ModuleDir() + "/"
|
mydir := mctx.ModuleDir() + "/"
|
||||||
var files []string
|
var files []string
|
||||||
for _, apiver := range mctx.Module().(*prebuiltApis).properties.Api_dirs {
|
for _, apiver := range mctx.Module().(*prebuiltApis).properties.Api_dirs {
|
||||||
|
@ -115,7 +111,7 @@ func getPrebuiltFiles(mctx android.TopDownMutatorContext, name string) []string
|
||||||
return files
|
return files
|
||||||
}
|
}
|
||||||
|
|
||||||
func prebuiltSdkStubs(mctx android.TopDownMutatorContext) {
|
func prebuiltSdkStubs(mctx android.LoadHookContext) {
|
||||||
mydir := mctx.ModuleDir() + "/"
|
mydir := mctx.ModuleDir() + "/"
|
||||||
// <apiver>/<scope>/<module>.jar
|
// <apiver>/<scope>/<module>.jar
|
||||||
files := getPrebuiltFiles(mctx, "*.jar")
|
files := getPrebuiltFiles(mctx, "*.jar")
|
||||||
|
@ -123,12 +119,12 @@ func prebuiltSdkStubs(mctx android.TopDownMutatorContext) {
|
||||||
for _, f := range files {
|
for _, f := range files {
|
||||||
// create a Import module for each jar file
|
// create a Import module for each jar file
|
||||||
localPath := strings.TrimPrefix(f, mydir)
|
localPath := strings.TrimPrefix(f, mydir)
|
||||||
module, apiver, scope := parseJarPath(mctx, localPath)
|
module, apiver, scope := parseJarPath(localPath)
|
||||||
createImport(mctx, module, scope, apiver, localPath)
|
createImport(mctx, module, scope, apiver, localPath)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func prebuiltApiFiles(mctx android.TopDownMutatorContext) {
|
func prebuiltApiFiles(mctx android.LoadHookContext) {
|
||||||
mydir := mctx.ModuleDir() + "/"
|
mydir := mctx.ModuleDir() + "/"
|
||||||
// <apiver>/<scope>/api/<module>.txt
|
// <apiver>/<scope>/api/<module>.txt
|
||||||
files := getPrebuiltFiles(mctx, "api/*.txt")
|
files := getPrebuiltFiles(mctx, "api/*.txt")
|
||||||
|
@ -178,7 +174,7 @@ func prebuiltApiFiles(mctx android.TopDownMutatorContext) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func PrebuiltApisMutator(mctx android.TopDownMutatorContext) {
|
func createPrebuiltApiModules(mctx android.LoadHookContext) {
|
||||||
if _, ok := mctx.Module().(*prebuiltApis); ok {
|
if _, ok := mctx.Module().(*prebuiltApis); ok {
|
||||||
prebuiltApiFiles(mctx)
|
prebuiltApiFiles(mctx)
|
||||||
prebuiltSdkStubs(mctx)
|
prebuiltSdkStubs(mctx)
|
||||||
|
@ -191,9 +187,15 @@ func PrebuiltApisMutator(mctx android.TopDownMutatorContext) {
|
||||||
// generates a filegroup module named <module>-api.<scope>.<ver>.
|
// generates a filegroup module named <module>-api.<scope>.<ver>.
|
||||||
//
|
//
|
||||||
// It also creates <module>-api.<scope>.latest for the latest <ver>.
|
// It also creates <module>-api.<scope>.latest for the latest <ver>.
|
||||||
|
//
|
||||||
|
// Similarly, it generates a java_import for all API .jar files found under the
|
||||||
|
// directory where the Android.bp is located. Specifically, an API file located
|
||||||
|
// at ./<ver>/<scope>/api/<module>.jar generates a java_import module named
|
||||||
|
// <prebuilt-api-module>.<scope>.<ver>.<module>.
|
||||||
func PrebuiltApisFactory() android.Module {
|
func PrebuiltApisFactory() android.Module {
|
||||||
module := &prebuiltApis{}
|
module := &prebuiltApis{}
|
||||||
module.AddProperties(&module.properties)
|
module.AddProperties(&module.properties)
|
||||||
android.InitAndroidModule(module)
|
android.InitAndroidModule(module)
|
||||||
|
android.AddLoadHook(module, createPrebuiltApiModules)
|
||||||
return module
|
return module
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue