Created
          July 11, 2025 20:40 
        
      - 
      
- 
        Save aaron-prindle/efe10223b0f4e4e97d013374de512562 to your computer and use it in GitHub Desktop. 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | //go:build !ignore_autogenerated | |
| // +build !ignore_autogenerated | |
| /* | |
| Copyright The Kubernetes Authors. | |
| 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. | |
| */ | |
| // Code generated by validation-gen. DO NOT EDIT. | |
| package single_key | |
| import ( | |
| context "context" | |
| fmt "fmt" | |
| equality "k8s.io/apimachinery/pkg/api/equality" | |
| operation "k8s.io/apimachinery/pkg/api/operation" | |
| safe "k8s.io/apimachinery/pkg/api/safe" | |
| validate "k8s.io/apimachinery/pkg/api/validate" | |
| field "k8s.io/apimachinery/pkg/util/validation/field" | |
| testscheme "k8s.io/code-generator/cmd/validation-gen/testscheme" | |
| ) | |
| func init() { localSchemeBuilder.Register(RegisterValidations) } | |
| // RegisterValidations adds validation functions to the given scheme. | |
| // Public to allow building arbitrary schemes. | |
| func RegisterValidations(scheme *testscheme.Scheme) error { | |
| scheme.AddValidationFunc((*Struct)(nil), func(ctx context.Context, op operation.Operation, obj, oldObj interface{}) field.ErrorList { | |
| switch op.Request.SubresourcePath() { | |
| case "/": | |
| return Validate_Struct(ctx, op, nil /* fldPath */, obj.(*Struct), safe.Cast[*Struct](oldObj)) | |
| } | |
| return field.ErrorList{field.InternalError(nil, fmt.Errorf("no validation found for %T, subresource: %v", obj, op.Request.SubresourcePath()))} | |
| }) | |
| scheme.AddValidationFunc((*StructWithNestedTypedef)(nil), func(ctx context.Context, op operation.Operation, obj, oldObj interface{}) field.ErrorList { | |
| switch op.Request.SubresourcePath() { | |
| case "/": | |
| return Validate_StructWithNestedTypedef(ctx, op, nil /* fldPath */, obj.(*StructWithNestedTypedef), safe.Cast[*StructWithNestedTypedef](oldObj)) | |
| } | |
| return field.ErrorList{field.InternalError(nil, fmt.Errorf("no validation found for %T, subresource: %v", obj, op.Request.SubresourcePath()))} | |
| }) | |
| return nil | |
| } | |
| func Validate_Struct(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *Struct) (errs field.ErrorList) { | |
| // field Struct.TypeMeta has no validation | |
| // field Struct.Items | |
| errs = append(errs, | |
| func(fldPath *field.Path, obj, oldObj []Item) (errs field.ErrorList) { | |
| if op.Type == operation.Update && equality.Semantic.DeepEqual(obj, oldObj) { | |
| return nil // no changes | |
| } | |
| errs = append(errs, validate.SliceItem(ctx, op, fldPath, obj, oldObj, func(item *Item) bool { return item.Key == "target" }, func(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *Item) field.ErrorList { | |
| return validate.FixedResult(ctx, op, fldPath, obj, oldObj, false, "item Items[key=target]") | |
| })...) | |
| errs = append(errs, validate.Unique(ctx, op, fldPath, obj, oldObj, func(a Item, b Item) bool { return a.Key == b.Key })...) | |
| return | |
| }(fldPath.Child("items"), obj.Items, safe.Field(oldObj, func(oldObj *Struct) []Item { return oldObj.Items }))...) | |
| // field Struct.IntKeyItems | |
| errs = append(errs, | |
| func(fldPath *field.Path, obj, oldObj []IntKeyItem) (errs field.ErrorList) { | |
| if op.Type == operation.Update && equality.Semantic.DeepEqual(obj, oldObj) { | |
| return nil // no changes | |
| } | |
| errs = append(errs, validate.SliceItem(ctx, op, fldPath, obj, oldObj, func(item *IntKeyItem) bool { return item.IntField == 42 }, func(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *IntKeyItem) field.ErrorList { | |
| return validate.FixedResult(ctx, op, fldPath, obj, oldObj, false, "item IntKeyItems[intField=42]") | |
| })...) | |
| errs = append(errs, validate.Unique(ctx, op, fldPath, obj, oldObj, func(a IntKeyItem, b IntKeyItem) bool { return a.IntField == b.IntField })...) | |
| return | |
| }(fldPath.Child("intKeyItems"), obj.IntKeyItems, safe.Field(oldObj, func(oldObj *Struct) []IntKeyItem { return oldObj.IntKeyItems }))...) | |
| // field Struct.BoolKeyItems | |
| errs = append(errs, | |
| func(fldPath *field.Path, obj, oldObj []BoolKeyItem) (errs field.ErrorList) { | |
| if op.Type == operation.Update && equality.Semantic.DeepEqual(obj, oldObj) { | |
| return nil // no changes | |
| } | |
| errs = append(errs, validate.SliceItem(ctx, op, fldPath, obj, oldObj, func(item *BoolKeyItem) bool { return item.BoolField == true }, func(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *BoolKeyItem) field.ErrorList { | |
| return validate.FixedResult(ctx, op, fldPath, obj, oldObj, false, "item BoolKeyItems[boolField=true]") | |
| })...) | |
| errs = append(errs, validate.Unique(ctx, op, fldPath, obj, oldObj, func(a BoolKeyItem, b BoolKeyItem) bool { return a.BoolField == b.BoolField })...) | |
| return | |
| }(fldPath.Child("boolKeyItems"), obj.BoolKeyItems, safe.Field(oldObj, func(oldObj *Struct) []BoolKeyItem { return oldObj.BoolKeyItems }))...) | |
| // field Struct.TypedefItems | |
| errs = append(errs, | |
| func(fldPath *field.Path, obj, oldObj TypedefItemList) (errs field.ErrorList) { | |
| if op.Type == operation.Update && equality.Semantic.DeepEqual(obj, oldObj) { | |
| return nil // no changes | |
| } | |
| errs = append(errs, validate.SliceItem(ctx, op, fldPath, obj, oldObj, func(item *TypedefItem) bool { return item.ID == "typedef-target" }, func(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *TypedefItem) field.ErrorList { | |
| return validate.FixedResult(ctx, op, fldPath, obj, oldObj, false, "item TypedefItems[id=typedef-target]") | |
| })...) | |
| errs = append(errs, validate.Unique(ctx, op, fldPath, obj, oldObj, func(a TypedefItem, b TypedefItem) bool { return a.ID == b.ID })...) | |
| return | |
| }(fldPath.Child("typedefItems"), obj.TypedefItems, safe.Field(oldObj, func(oldObj *Struct) TypedefItemList { return oldObj.TypedefItems }))...) | |
| // field Struct.DualItems | |
| errs = append(errs, | |
| func(fldPath *field.Path, obj, oldObj DualItemList) (errs field.ErrorList) { | |
| if op.Type == operation.Update && equality.Semantic.DeepEqual(obj, oldObj) { | |
| return nil // no changes | |
| } | |
| errs = append(errs, validate.SliceItem(ctx, op, fldPath, obj, oldObj, func(item *DualItem) bool { return item.ID == "field-target" }, func(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *DualItem) field.ErrorList { | |
| return validate.FixedResult(ctx, op, fldPath, obj, oldObj, false, "item DualItems[id=field-target] from field") | |
| })...) | |
| errs = append(errs, validate.SliceItem(ctx, op, fldPath, obj, oldObj, func(item *DualItem) bool { return item.ID == "typedef-target" }, func(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *DualItem) field.ErrorList { | |
| return validate.FixedResult(ctx, op, fldPath, obj, oldObj, false, "item DualItems[id=typedef-target] from typedef") | |
| })...) | |
| errs = append(errs, validate.Unique(ctx, op, fldPath, obj, oldObj, func(a DualItem, b DualItem) bool { return a.ID == b.ID })...) | |
| return | |
| }(fldPath.Child("dualItems"), obj.DualItems, safe.Field(oldObj, func(oldObj *Struct) DualItemList { return oldObj.DualItems }))...) | |
| return errs | |
| } | |
| func Validate_StructWithNestedTypedef(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *StructWithNestedTypedef) (errs field.ErrorList) { | |
| // field StructWithNestedTypedef.TypeMeta has no validation | |
| // field StructWithNestedTypedef.NestedItems | |
| errs = append(errs, | |
| func(fldPath *field.Path, obj, oldObj []NestedTypedefItem) (errs field.ErrorList) { | |
| if op.Type == operation.Update && equality.Semantic.DeepEqual(obj, oldObj) { | |
| return nil // no changes | |
| } | |
| errs = append(errs, validate.SliceItem(ctx, op, fldPath, obj, oldObj, func(item *NestedTypedefItem) bool { return item.Key == "nested-target" }, func(ctx context.Context, op operation.Operation, fldPath *field.Path, obj, oldObj *NestedTypedefItem) field.ErrorList { | |
| return validate.FixedResult(ctx, op, fldPath, obj, oldObj, false, "item NestedItems[key=nested-target]") | |
| })...) | |
| errs = append(errs, validate.Unique(ctx, op, fldPath, obj, oldObj, func(a NestedTypedefItem, b NestedTypedefItem) bool { return a.Key == b.Key })...) | |
| return | |
| }(fldPath.Child("nestedItems"), obj.NestedItems, safe.Field(oldObj, func(oldObj *StructWithNestedTypedef) []NestedTypedefItem { return oldObj.NestedItems }))...) | |
| return errs | |
| } | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment