Support %s in product variable properties am: 7e0eaf15b9 am: d75b9109cc

am: a4ca1b6caf

Change-Id: Iaa65bd0e000f79b4ec4c13d0f6d1955d08cb601d
This commit is contained in:
Colin Cross
2017-05-06 01:48:01 +00:00
committed by android-build-merger
3 changed files with 175 additions and 12 deletions

View File

@@ -231,7 +231,7 @@ func variableMutator(mctx BottomUpMutatorContext) {
func (a *ModuleBase) setVariableProperties(ctx BottomUpMutatorContext,
prefix string, productVariablePropertyValue reflect.Value, variableValue interface{}) {
printfIntoProperties(productVariablePropertyValue, variableValue)
printfIntoProperties(ctx, prefix, productVariablePropertyValue, variableValue)
err := proptools.AppendMatchingProperties(a.generalProperties,
productVariablePropertyValue.Addr().Interface(), nil)
@@ -244,7 +244,17 @@ func (a *ModuleBase) setVariableProperties(ctx BottomUpMutatorContext,
}
}
func printfIntoProperties(productVariablePropertyValue reflect.Value, variableValue interface{}) {
func printfIntoPropertiesError(ctx BottomUpMutatorContext, prefix string,
productVariablePropertyValue reflect.Value, i int, err error) {
field := productVariablePropertyValue.Type().Field(i).Name
property := prefix + "." + proptools.PropertyNameForField(field)
ctx.PropertyErrorf(property, "%s", err)
}
func printfIntoProperties(ctx BottomUpMutatorContext, prefix string,
productVariablePropertyValue reflect.Value, variableValue interface{}) {
for i := 0; i < productVariablePropertyValue.NumField(); i++ {
propertyValue := productVariablePropertyValue.Field(i)
kind := propertyValue.Kind()
@@ -256,36 +266,64 @@ func printfIntoProperties(productVariablePropertyValue reflect.Value, variableVa
}
switch propertyValue.Kind() {
case reflect.String:
printfIntoProperty(propertyValue, variableValue)
err := printfIntoProperty(propertyValue, variableValue)
if err != nil {
printfIntoPropertiesError(ctx, prefix, productVariablePropertyValue, i, err)
}
case reflect.Slice:
for j := 0; j < propertyValue.Len(); j++ {
printfIntoProperty(propertyValue.Index(j), variableValue)
err := printfIntoProperty(propertyValue.Index(j), variableValue)
if err != nil {
printfIntoPropertiesError(ctx, prefix, productVariablePropertyValue, i, err)
}
}
case reflect.Bool:
// Nothing
case reflect.Struct:
printfIntoProperties(propertyValue, variableValue)
printfIntoProperties(ctx, prefix, propertyValue, variableValue)
default:
panic(fmt.Errorf("unsupported field kind %q", propertyValue.Kind()))
}
}
}
func printfIntoProperty(propertyValue reflect.Value, variableValue interface{}) {
func printfIntoProperty(propertyValue reflect.Value, variableValue interface{}) error {
s := propertyValue.String()
// For now, we only support int formats
var i int
count := strings.Count(s, "%")
if count == 0 {
return nil
}
if count > 1 {
return fmt.Errorf("product variable properties only support a single '%%'")
}
if strings.Contains(s, "%d") {
switch v := variableValue.(type) {
case int:
i = v
// Nothing
case bool:
if v {
i = 1
variableValue = 1
} else {
variableValue = 0
}
default:
panic(fmt.Errorf("unsupported type %T", variableValue))
return fmt.Errorf("unsupported type %T for %%d", variableValue)
}
propertyValue.Set(reflect.ValueOf(fmt.Sprintf(s, i)))
} else if strings.Contains(s, "%s") {
switch variableValue.(type) {
case string:
// Nothing
default:
return fmt.Errorf("unsupported type %T for %%s", variableValue)
}
} else {
return fmt.Errorf("unsupported %% in product variable property")
}
propertyValue.Set(reflect.ValueOf(fmt.Sprintf(s, variableValue)))
return nil
}