Enable Soong to correctly add dependencies to .PHONY targets.
Previously, Soong's phony simply added "required" or "host_required" to LOCAL_REQUIRED_MODULES and `include BUILD_PHONY_PACKAGE` without correctly adding them to the dependency list. This change add a new `phony_rule` module type to Soong that acts like `.PHONY` instead of `BUILD_PHONY_PACKAGE` Bug: 316838256 Bug: 309730110 Test: 1. Use `phony_rule` and adding "phony_deps: [dep_modules]" to Android.bp. 2. make target and check the dep_modules be built. Change-Id: I3e9e9ac26ecc456668f1b6baf5c08f9c9139b3b2
This commit is contained in:
parent
ad579a8c71
commit
f3c706868a
2 changed files with 39 additions and 0 deletions
|
@ -852,6 +852,7 @@ func translateAndroidModule(ctx SingletonContext, w io.Writer, mod blueprint.Mod
|
|||
case "*java.SystemModules": // doesn't go through base_rules
|
||||
case "*java.systemModulesImport": // doesn't go through base_rules
|
||||
case "*phony.phony": // license properties written
|
||||
case "*phony.PhonyRule": // writes phony deps and acts like `.PHONY`
|
||||
case "*selinux.selinuxContextsModule": // license properties written
|
||||
case "*sysprop.syspropLibrary": // license properties written
|
||||
default:
|
||||
|
|
|
@ -24,6 +24,7 @@ import (
|
|||
|
||||
func init() {
|
||||
android.RegisterModuleType("phony", PhonyFactory)
|
||||
android.RegisterModuleType("phony_rule", PhonyRuleFactory)
|
||||
}
|
||||
|
||||
type phony struct {
|
||||
|
@ -71,3 +72,40 @@ func (p *phony) AndroidMk() android.AndroidMkData {
|
|||
},
|
||||
}
|
||||
}
|
||||
|
||||
type PhonyRule struct {
|
||||
android.ModuleBase
|
||||
|
||||
properties PhonyProperties
|
||||
}
|
||||
|
||||
type PhonyProperties struct {
|
||||
// The Phony_deps is the set of all dependencies for this target,
|
||||
// and it can function similarly to .PHONY in a makefile.
|
||||
// Additionally, dependencies within it can even include genrule.
|
||||
Phony_deps []string
|
||||
}
|
||||
|
||||
// The phony_rule provides functionality similar to the .PHONY in a makefile.
|
||||
// It can create a phony target and include relevant dependencies associated with it.
|
||||
func PhonyRuleFactory() android.Module {
|
||||
module := &PhonyRule{}
|
||||
android.InitAndroidModule(module)
|
||||
module.AddProperties(&module.properties)
|
||||
return module
|
||||
}
|
||||
|
||||
func (p *PhonyRule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
||||
}
|
||||
|
||||
func (p *PhonyRule) AndroidMk() android.AndroidMkData {
|
||||
return android.AndroidMkData{
|
||||
Custom: func(w io.Writer, name, prefix, moduleDir string, data android.AndroidMkData) {
|
||||
if len(p.properties.Phony_deps) > 0 {
|
||||
depModulesStr := strings.Join(p.properties.Phony_deps, " ")
|
||||
fmt.Fprintln(w, ".PHONY:", name)
|
||||
fmt.Fprintln(w, name, ":", depModulesStr)
|
||||
}
|
||||
},
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue