- Allow each of the formats (json, pb, textproto) to be individually controlled. - Include product and release in the name of the aritfact. Bug: 328495189 Test: manual Change-Id: Ia08e7224200a48994bea882a61b8199d53576d38
74 lines
1.9 KiB
Go
74 lines
1.9 KiB
Go
// Copyright 2024 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 release_config_lib
|
|
|
|
import (
|
|
"strings"
|
|
|
|
rc_proto "android/soong/cmd/release_config/release_config_proto"
|
|
)
|
|
|
|
type FlagValue struct {
|
|
// The path providing this value.
|
|
path string
|
|
|
|
// Protobuf
|
|
proto rc_proto.FlagValue
|
|
}
|
|
|
|
func FlagValueFactory(protoPath string) (fv *FlagValue) {
|
|
fv = &FlagValue{path: protoPath}
|
|
if protoPath != "" {
|
|
LoadMessage(protoPath, &fv.proto)
|
|
}
|
|
return fv
|
|
}
|
|
|
|
func UnmarshalValue(str string) *rc_proto.Value {
|
|
ret := &rc_proto.Value{}
|
|
switch v := strings.ToLower(str); v {
|
|
case "true":
|
|
ret = &rc_proto.Value{Val: &rc_proto.Value_BoolValue{true}}
|
|
case "false":
|
|
ret = &rc_proto.Value{Val: &rc_proto.Value_BoolValue{false}}
|
|
case "##obsolete":
|
|
ret = &rc_proto.Value{Val: &rc_proto.Value_Obsolete{true}}
|
|
default:
|
|
ret = &rc_proto.Value{Val: &rc_proto.Value_StringValue{str}}
|
|
}
|
|
return ret
|
|
}
|
|
|
|
func MarshalValue(value *rc_proto.Value) string {
|
|
switch val := value.Val.(type) {
|
|
case *rc_proto.Value_UnspecifiedValue:
|
|
// Value was never set.
|
|
return ""
|
|
case *rc_proto.Value_StringValue:
|
|
return val.StringValue
|
|
case *rc_proto.Value_BoolValue:
|
|
if val.BoolValue {
|
|
return "true"
|
|
}
|
|
// False ==> empty string
|
|
return ""
|
|
case *rc_proto.Value_Obsolete:
|
|
return " #OBSOLETE"
|
|
default:
|
|
// Flagged as error elsewhere, so return empty string here.
|
|
return ""
|
|
}
|
|
}
|