Skip to content

Commit

Permalink
Handle List of enum kind
Browse files Browse the repository at this point in the history
  • Loading branch information
gemmahou committed Jul 15, 2024
1 parent e8c8b0d commit 0609b10
Showing 1 changed file with 30 additions and 7 deletions.
37 changes: 30 additions & 7 deletions dev/tools/controllerbuilder/pkg/codegen/mappergenerator.go
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,7 @@ func (v *MapperGenerator) writeMapFunctionsForPair(out io.Writer, pair *typePair
}

if protoField.Cardinality() == protoreflect.Repeated {
useSliceFromProto := ""
useSliceFromProtoFunction := ""
useCustomMethod := false

switch protoField.Kind() {
Expand All @@ -225,12 +225,22 @@ func (v *MapperGenerator) writeMapFunctionsForPair(out io.Writer, pair *typePair
krmElemTypeName = strings.TrimPrefix(krmElemTypeName, "[]")

functionName := krmElemTypeName + "_FromProto"
useSliceFromProto = functionName
useSliceFromProtoFunction = functionName
case protoreflect.StringKind:
if krmField.Type != "[]string" {
useCustomMethod = true
// useSliceFromProto = fmt.Sprintf("%s_%s_FromProto", goTypeName, protoFieldName)
}
case protoreflect.EnumKind:
krmElemTypeName := krmField.Type
krmElemTypeName = strings.TrimPrefix(krmElemTypeName, "*")
krmElemTypeName = strings.TrimPrefix(krmElemTypeName, "[]")

functionName := "Enum_FromProto"
useSliceFromProtoFunction = fmt.Sprintf("%s(mapCtx, in.%s)",
functionName,
krmFieldName,
)

case
protoreflect.FloatKind,
Expand All @@ -241,7 +251,7 @@ func (v *MapperGenerator) writeMapFunctionsForPair(out io.Writer, pair *typePair
protoreflect.Uint32Kind,
protoreflect.Uint64Kind,
protoreflect.BytesKind:
useSliceFromProto = ""
useSliceFromProtoFunction = ""
default:
klog.Fatalf("unhandled kind %q for repeated field %v", protoField.Kind(), protoField)
}
Expand All @@ -251,19 +261,19 @@ func (v *MapperGenerator) writeMapFunctionsForPair(out io.Writer, pair *typePair
keyKind := entryMsg.Fields().ByName("key").Kind()
valueKind := entryMsg.Fields().ByName("value").Kind()
if keyKind == protoreflect.StringKind && valueKind == protoreflect.StringKind {
useSliceFromProto = ""
useSliceFromProtoFunction = ""
} else if keyKind == protoreflect.StringKind && valueKind == protoreflect.Int64Kind {
useSliceFromProto = ""
useSliceFromProtoFunction = ""
} else {
fmt.Fprintf(out, "// TODO: map type %v %v\n", keyKind, valueKind)
}
}

if useSliceFromProto != "" {
if useSliceFromProtoFunction != "" {
fmt.Fprintf(out, "\tout.%s = Slice_FromProto(mapCtx, in.%s, %s)\n",
krmFieldName,
krmFieldName,
useSliceFromProto,
useSliceFromProtoFunction,
)
} else if useCustomMethod {
methodName := fmt.Sprintf("%s_%s_FromProto", goTypeName, protoFieldName)
Expand Down Expand Up @@ -362,6 +372,19 @@ func (v *MapperGenerator) writeMapFunctionsForPair(out io.Writer, pair *typePair
//useSliceToProtoFunction = fmt.Sprintf("%s_%s_ToProto", goTypeName, protoFieldName)
}

case protoreflect.EnumKind:
krmElemTypeName := krmField.Type
krmElemTypeName = strings.TrimPrefix(krmElemTypeName, "*")
krmElemTypeName = strings.TrimPrefix(krmElemTypeName, "[]")

protoTypeName := "pb." + protoNameForEnum(protoField.Enum())
functionName := "Enum_ToProto"
useSliceToProtoFunction = fmt.Sprintf("%s[%s](mapCtx, in.%s)",
functionName,
protoTypeName,
krmFieldName,
)

case protoreflect.FloatKind,
protoreflect.DoubleKind,
protoreflect.BoolKind,
Expand Down

0 comments on commit 0609b10

Please sign in to comment.