Add PropertyCustomizer
am: a120ec1c5e
Change-Id: Ia6241e8063bf07a0b63aa9a9ca6718e9db36c26b
This commit is contained in:
@@ -94,6 +94,7 @@ bootstrap_go_package {
|
|||||||
"android/androidmk.go",
|
"android/androidmk.go",
|
||||||
"android/arch.go",
|
"android/arch.go",
|
||||||
"android/config.go",
|
"android/config.go",
|
||||||
|
"android/customizer.go",
|
||||||
"android/defaults.go",
|
"android/defaults.go",
|
||||||
"android/defs.go",
|
"android/defs.go",
|
||||||
"android/glob.go",
|
"android/glob.go",
|
||||||
|
@@ -24,13 +24,6 @@ import (
|
|||||||
"github.com/google/blueprint/proptools"
|
"github.com/google/blueprint/proptools"
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
|
||||||
RegisterBottomUpMutator("defaults_deps", defaultsDepsMutator).Parallel()
|
|
||||||
RegisterTopDownMutator("defaults", defaultsMutator).Parallel()
|
|
||||||
|
|
||||||
RegisterBottomUpMutator("arch", ArchMutator).Parallel()
|
|
||||||
}
|
|
||||||
|
|
||||||
var (
|
var (
|
||||||
Arm = newArch("arm", "lib32")
|
Arm = newArch("arm", "lib32")
|
||||||
Arm64 = newArch("arm64", "lib64")
|
Arm64 = newArch("arm64", "lib64")
|
||||||
@@ -490,6 +483,8 @@ func InitArchModule(m Module,
|
|||||||
allProperties = append(allProperties, asp)
|
allProperties = append(allProperties, asp)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
base.customizableProperties = allProperties
|
||||||
|
|
||||||
return m, allProperties
|
return m, allProperties
|
||||||
}
|
}
|
||||||
|
|
||||||
|
77
android/customizer.go
Normal file
77
android/customizer.go
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
// Copyright 2016 Google Inc. All rights reserved.
|
||||||
|
//
|
||||||
|
// 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 android
|
||||||
|
|
||||||
|
import "github.com/google/blueprint/proptools"
|
||||||
|
|
||||||
|
type CustomizePropertiesContext interface {
|
||||||
|
BaseContext
|
||||||
|
AppendProperties(...interface{})
|
||||||
|
PrependProperties(...interface{})
|
||||||
|
}
|
||||||
|
|
||||||
|
type customizePropertiesContext struct {
|
||||||
|
BaseContext
|
||||||
|
|
||||||
|
module *ModuleBase
|
||||||
|
}
|
||||||
|
|
||||||
|
type PropertyCustomizer interface {
|
||||||
|
CustomizeProperties(CustomizePropertiesContext)
|
||||||
|
}
|
||||||
|
|
||||||
|
func customizerMutator(ctx TopDownMutatorContext) {
|
||||||
|
if m, ok := ctx.Module().(Module); ok {
|
||||||
|
a := m.base()
|
||||||
|
if len(a.customizers) > 0 {
|
||||||
|
mctx := &customizePropertiesContext{
|
||||||
|
BaseContext: ctx,
|
||||||
|
module: a,
|
||||||
|
}
|
||||||
|
for _, c := range a.customizers {
|
||||||
|
c.CustomizeProperties(mctx)
|
||||||
|
if mctx.Failed() {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ctx *customizePropertiesContext) AppendProperties(props ...interface{}) {
|
||||||
|
for _, p := range props {
|
||||||
|
err := proptools.AppendMatchingProperties(ctx.module.customizableProperties, p, nil)
|
||||||
|
if err != nil {
|
||||||
|
if propertyErr, ok := err.(*proptools.ExtendPropertyError); ok {
|
||||||
|
ctx.PropertyErrorf(propertyErr.Property, "%s", propertyErr.Err.Error())
|
||||||
|
} else {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ctx *customizePropertiesContext) PrependProperties(props ...interface{}) {
|
||||||
|
for _, p := range props {
|
||||||
|
err := proptools.PrependMatchingProperties(ctx.module.customizableProperties, p, nil)
|
||||||
|
if err != nil {
|
||||||
|
if propertyErr, ok := err.(*proptools.ExtendPropertyError); ok {
|
||||||
|
ctx.PropertyErrorf(propertyErr.Property, "%s", propertyErr.Err.Error())
|
||||||
|
} else {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -25,6 +25,14 @@ import (
|
|||||||
"github.com/google/blueprint"
|
"github.com/google/blueprint"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
RegisterTopDownMutator("customizer", customizerMutator).Parallel()
|
||||||
|
RegisterBottomUpMutator("defaults_deps", defaultsDepsMutator).Parallel()
|
||||||
|
RegisterTopDownMutator("defaults", defaultsMutator).Parallel()
|
||||||
|
|
||||||
|
RegisterBottomUpMutator("arch", ArchMutator).Parallel()
|
||||||
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
DeviceSharedLibrary = "shared_library"
|
DeviceSharedLibrary = "shared_library"
|
||||||
DeviceStaticLibrary = "static_library"
|
DeviceStaticLibrary = "static_library"
|
||||||
@@ -188,6 +196,11 @@ func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib
|
|||||||
return InitArchModule(m, propertyStructs...)
|
return InitArchModule(m, propertyStructs...)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func AddCustomizer(m blueprint.Module, c PropertyCustomizer) {
|
||||||
|
base := m.(Module).base()
|
||||||
|
base.customizers = append(base.customizers, c)
|
||||||
|
}
|
||||||
|
|
||||||
// A AndroidModuleBase object contains the properties that are common to all Android
|
// A AndroidModuleBase object contains the properties that are common to all Android
|
||||||
// modules. It should be included as an anonymous field in every module
|
// modules. It should be included as an anonymous field in every module
|
||||||
// struct definition. InitAndroidModule should then be called from the module's
|
// struct definition. InitAndroidModule should then be called from the module's
|
||||||
@@ -238,6 +251,7 @@ type ModuleBase struct {
|
|||||||
hostAndDeviceProperties hostAndDeviceProperties
|
hostAndDeviceProperties hostAndDeviceProperties
|
||||||
generalProperties []interface{}
|
generalProperties []interface{}
|
||||||
archProperties []*archProperties
|
archProperties []*archProperties
|
||||||
|
customizableProperties []interface{}
|
||||||
|
|
||||||
noAddressSanitizer bool
|
noAddressSanitizer bool
|
||||||
installFiles Paths
|
installFiles Paths
|
||||||
@@ -248,6 +262,8 @@ type ModuleBase struct {
|
|||||||
installTarget string
|
installTarget string
|
||||||
checkbuildTarget string
|
checkbuildTarget string
|
||||||
blueprintDir string
|
blueprintDir string
|
||||||
|
|
||||||
|
customizers []PropertyCustomizer
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *ModuleBase) base() *ModuleBase {
|
func (a *ModuleBase) base() *ModuleBase {
|
||||||
|
Reference in New Issue
Block a user